283. 移动零
解题思路
很简单的双指针,每次交换,都是将左指针的零与右指针的非零数交换,且非零数的相对顺序并未改变。
代码
class Solution {
public void moveZeroes(int[] nums) {
int n = nums.length, left = 0, right = 0;
while (right < n) {
if (nums[right] != 0) {
swap(nums, left, right);
left++;
}
right++;
}
}
public void swap(int[] nums, int left, int right) {
int temp = nums[left];
nums[left] = nums[right];
nums[right] = temp;
}
}