题目:
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
代码:
void moveZeroes(int* nums, int numsSize){
if (numsSize <= 1) {
return 0;
}
int j = 0;
for(int i = 0; i < numsSize; i++) {
if(nums[i] != 0) {
int tmp = nums[i];
nums[i] = nums[j];
nums[j++] = tmp;
}
}
}
思路:
定义两个变量,并将其中一个进行遍历。遇到非0元素,就交换到左边。
运行结果: