个人主页:Lei宝啊
愿所有美好如期而遇
算法原理
双指针法,不一定是说就要使用指针,只是一种形象的说法,在数组中,我们一般将数组下标当做指针,比如我们定义cur,dest,cur的左边都是处理过的,dest左边的都是非0,dest和cur中间的都是0。开始我们将cur赋值0,因为我们不知道下标为0的元素是否是0,所以dest我们赋值为-1,如果cur指向的元素值为0,那么cur++,如果不为0,那么dest++,然后和cur指向的元素交换值,cur++。我们重复上述步骤,直到cur走到尽头。
图示
代码
class Solution { public: void moveZeroes(vector<int>& nums) { int cur = 0; int dest= -1; while(cur < nums.size()) { if(nums[cur] != 0) { swap(nums[cur++],nums[++dest]); } else { cur++; } } } };