给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。 请注意 ,必须在不复制数组的情况下原地对数组进行操作。
时间: 2024-10-22 16:20:20 浏览: 44
88合并两个有序数组.zip
这个问题通常被称为“0 零分离”或者“0 移动到末尾”,它是一个常见的面试题,涉及到数组操作和双指针的概念。你可以通过两个指针,一个左指针 i 和一个右指针 j,来解决这个任务。具体步骤如下:
1. 初始化两个指针,i 指向数组开始位置,j 指向数组结束位置。
2. 当 i 小于等于 j 时,循环执行以下操作:
- 如果 nums[i] 不是 0,将它移动到 nums[j+1] 的位置,然后 j 后移一位。
- 否则,如果 nums[i] 是 0,则 i 自增一位。
3. 循环结束后,nums 中从索引 i 到 end 的部分都是 0。
以下是 Python 代码示例:
```python
def moveZeroes(nums):
left = 0
for right in range(len(nums)):
if nums[right] != 0:
nums[left], nums[right] = nums[right], nums[left]
left += 1
while left < len(nums):
nums[left] = 0
left += 1
```
阅读全文