给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序:
示例:
输入: [0,1,0,3,12]
输出: [1,3,12,0,0]
说明:
必须在原数组上操作,不能拷贝额外的数组。
尽量减少操作次数
解:
首先想到再开辟一个新的数组,然后遍历原数组将非0元素添加到新数组中,当原数组遍历完成后新数组剩下的都填0即可,但是在题意说明中必须在原数组上操作,所以得用其他巧妙的方法。
可以利用双指针i,j,i指向当前遍历到的元素,j随i一起走动,但是如果遇到0,j就停下来,当i指向的元素不为0时,i指向的元素和j指向的元素发生一次交换。
public void moveZeroes(int[] nums) {
if (nums == null || nums.length == 0) {
return;
}
int j = 0;
for (int i = 0; i < nums.length; i++) {
if (nums[i] != 0) {
int temp = nums[i];
nums[i] = nums[j];
nums[j] = temp;
j++;
}
}
}
因为我们遍历了一次数组,所以平均时间复杂度为O(n),只用到了两个指针i,j,所以空间复杂度为O(1)。