leetcode刷题日记 双指针(二)
作者:互联网
题目描述
283. 移动零
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
示例:
输入: [0,1,0,3,12]
输出: [1,3,12,0,0]
说明:
必须在原数组上操作,不能拷贝额外的数组。
尽量减少操作次数。
思路
使用两个下标i,j
i始终指向未排序的最后一个,j从前往后遍历寻找非零数,如果找到非零数那么就将nums[i],nums[j]进行交换,也就是将当前的最小非零数交换到最前面去。
C++代码:
class Solution {
public:
void moveZeroes(vector<int>& nums) {
int n = nums.size(), left = 0, right = 0;
while (right < n) {
if (nums[right]) {
swap(nums[left], nums[right]);
left++;
}
right++;
}
}
};
标签:right,nums,++,零数,数组,left,刷题,leetcode,指针 来源: https://blog.csdn.net/qq_43336475/article/details/120752484