数组元素循环左移n位
时间: 2024-06-19 09:03:17 浏览: 113
数组元素循环左移n位是指将一个数组中的所有元素向左循环移动n个位置,移动后超出数组边界的元素会重新回到数组的另一端。以下是一个例子:
原数组:[1, 2, 3, 4, 5, 6]
左移2位后的数组:[3, 4, 5, 6, 1, 2]
具体实现方法可以使用三次翻转操作,如下:
1. 翻转数组前n个元素
2. 翻转数组后面剩余的元素
3. 翻转整个数组
这样就可以完成循环左移n位的操作了。
相关问题
数组元素循环左移n位函数题
好的,这是一个常见的数组操作题目,以下是一个实现此功能的示例代码:
```python
def left_rotate_array(arr, n):
"""
将数组arr中的元素循环左移n位
"""
length = len(arr)
n %= length # 如果n大于数组长度,取余数
arr[:n] = arr[:n][::-1] # 反转前n个元素
arr[n:] = arr[n:][::-1] # 反转剩下的元素
arr[:] = arr[::-1] # 反转整个数组
```
其中,`arr`为要进行操作的数组,`n`为左移的位数。代码首先对`n`进行取余,以防`n`大于数组长度。然后,将前`n`个元素反转,再将剩下的元素反转,最后将整个数组反转,即可实现左移`n`位的操作。
示例调用:
```python
arr = [1, 2, 3, 4, 5]
left_rotate_array(arr, 2)
print(arr) # 输出:[3, 4, 5, 1, 2]
```
这个函数可以将数组`[1, 2, 3, 4, 5]`左移2位,结果为`[3, 4, 5, 1, 2]`。
Java实现数组元素循环左移n位函数题,时间复杂度和空间复杂度
好的,下面是一个可能的Java实现:
```java
public static void rotate(int[] nums, int k) {
int n = nums.length;
k = k % n;
reverse(nums, 0, n - 1);
reverse(nums, 0, k - 1);
reverse(nums, k, n - 1);
}
private static void reverse(int[] nums, int start, int end) {
while (start < end) {
int temp = nums[start];
nums[start] = nums[end];
nums[end] = temp;
start++;
end--;
}
}
```
时间复杂度是O(n),其中n是数组的长度,因为需要遍历整个数组三次。空间复杂度是O(1),因为只需要常数个额外变量作为辅助空间,不会随着数组长度的增加而增加。
阅读全文