You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

54 lines
1.4 KiB
Markdown

7 years ago
<h1 align="center">Array Rotation Source</h1>
[What It Is](#what-it-is)
## What It Is
7 years ago
> * Input: Write a function `rotate(ar[], d, n)` that rotates `arr[]` of size `n` by `d` elements
> * Output: `1 2 3 4 5 6 7`
7 years ago
7 years ago
> * Input: Rotation of the above array by `2` will make array
> * Output: `3 4 5 6 7 1 2`
7 years ago
METHOD 1 (Use temp array)
--------------------------
Input arr[] = [1, 2, 3, 4, 5, 6, 7], d = 2, n =7
7 years ago
* 1) Store `d` elements in a temp array
temp[] = [1, 2]
7 years ago
* 2) Shift rest of the `arr[]`
arr[] = [3, 4, 5, 6, 7, 6, 7]
7 years ago
* 3) Store back the `d` elements
arr[] = [3, 4, 5, 6, 7, 1, 2]
7 years ago
**Algorithm Complexity**
| Complexity | Notation |
| ----------------- |:---------:|
| `Time Complexity` | `O(n)` |
| `Auxiliary Space` | `O(d)` |
7 years ago
METHOD 2 (Rotate one by one)
--------------------------
```go
leftRotate(arr[], d, n)
start
For i = 0 to i < d
Left rotate all elements of arr[] by one
end
```
To rotate by one, store arr[0] in a temporary variable temp, move arr[1] to arr[0], arr[2] to arr[1] …and finally temp to arr[n-1]
Let us take the same example arr[] = [1, 2, 3, 4, 5, 6, 7], d = 2
Rotate arr[] by one 2 times
We get `[2, 3, 4, 5, 6, 7, 1]` after first rotation and `[3, 4, 5, 6, 7, 1, 2]` after second rotation.
7 years ago
**Algorithm Complexity**
| Complexity | Notation |
| ----------------- |:---------:|
| `Time Complexity` | `O(n*d)` |
| `Auxiliary Space` | `O(1)` |