283. 移动零



283. 移动零

难度简单968

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

示例:

输入: [0,1,0,3,12]

输出: [1,3,12,0,0]

说明:

  1. 必须在原数组上操作,不能拷贝额外的数组。
  2. 尽量减少操作次数。

不太好理解

 public void moveZeroes(int[] nums) {
        int n = nums.length, left = 0, right = 0;
        while (right < n) &#123;
            if (nums[right] != 0) &#123;
                swap(nums, left, right);
                left++;
            &#125;
            right++;
        &#125;
    &#125;

    public void swap(int[] nums, int left, int right) &#123;
        int temp = nums[left];
        nums[left] = nums[right];
        nums[right] = temp;
    &#125;

双指针

思路及解法

使用双指针,左指针指向当前已经处理好的序列的尾部,右指针指向待处理序列的头部。

右指针不断向右移动,每次右指针指向非零数,则将左右指针对应的数交换,同时左指针右移。

注意到以下性质:

左指针左边均为非零数;

右指针左边直到左指针处均为零。

因此每次交换,都是将左指针的零与右指针的非零数交换,且非零数的相对顺序并未改变。


易理解

    public void moveZeroes1(int[] nums) &#123;
        int indexNow = 0;
        int indexNum = 0;
        int m = nums.length;

        while(indexNum<m)&#123;
            if(nums[indexNum] != 0) &#123;
                nums[indexNow++] = nums[indexNum];
            &#125;
            ++indexNum;
        &#125;

        for(int i = indexNow; i < m; i++)&#123;
            nums[i] = 0;
        &#125;
    &#125;

都知道是 0,还换啥?覆盖,后面补 0 就行了.


文章作者:   future
版权声明:   本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 future !
 上一篇
189. 旋转数组 189. 旋转数组
189. 旋转数组难度中等 893 给定一个数组,将数组中的元素向右移动 k_ 个位置,其中 k _是非负数。 进阶: 尽可能想出更多的解决方案,至少有三种不同的方法可以解决这个问题。 你可以使用空间复杂度为  O(1) 的 **原地
2021-03-03 future
下一篇 
198. 打家劫舍 198. 打家劫舍
198. 打家劫舍难度中等 1295 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个
  目录