其他分享
首页 > 其他分享> > leetcode刷题日记 双指针(二)

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