leecode刷题(8)-- 移动零

作者: 希希里之海 | 来源:发表于2019-01-16 13:39 被阅读5次

leecode刷题(8)-- 移动零

移动零

描述:

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

示例:

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

说明:

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

思路:

依据题目,我们将数组中值不为 0 的元素往前移,将值为 0 的元素移动到最后面。可以设置一个数组元素下标,初始化为 0,从前往后遍历数组,当遇到值为 0 的元素时让其和初始化为 0 的下标对应的元素交换,然后下标加 1 ,这样遍历下来,我们便将值不为 0 的元素移动到了前面,值为 0 的元素自然而然就放在后面了。

代码如下:

import java.util.Arrays;

public class MoveZeroes {
    public static void moveZeroes(int[] nums) {
        if (nums == null || nums.length == 0 || nums.length == 1) {
            return ;
        }
        int index = 0;
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] != 0) {
                int temp = nums[i];
                nums[i] = nums[index];
                nums[index++] = temp;
            }
        }
    }

    public static void main(String[] args) {
        int[] nums = {0,1,0,3,12};
        moveZeroes(nums);
        System.out.println(Arrays.toString(nums));
    }
}

另一种写法:

这种写法和刚刚的写法差不多,把数组中所有的非零元素,按顺序给数组的前段元素位赋值,剩下的全部直接赋值0。其实和上边相比,就多了个赋值 0 的操作,还没那么简洁,建议采取第一种(破涕而笑)。但是还是自己写出来的,记录一下,哈哈。

import java.util.Arrays;

public class MoveZeroes {
    public static void moveZeroes(int[] nums) {
        if (nums == null || nums.length == 0 || nums.length == 1) {
            return ;
        }
        int index = 0;
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] != 0) {
                nums[index] = nums[i];
                ++index;
                /*
                nums[index] = nums[i];
                ++index;
                这两句可以简写成:
                nums[index++] = nums[i]; 简化一点
                */
            }
        }
        for (int i = index; i < nums.length; i++) {
            nums[i] = 0;
        }
    }

    public static void main(String[] args) {
        int[] nums = {0,1,0,3,12};
        moveZeroes(nums);
        System.out.println(Arrays.toString(nums));
    }
}

相关文章

  • leecode刷题(8)-- 移动零

    leecode刷题(8)-- 移动零 移动零 描述: 给定一个数组 nums,编写一个函数将所有 0 移动到数组的...

  • Leecode刷题

    刚发现leecode只需要编写主函数就行,不必去纠结读取输入和输出 1、给定一个整数数组 nums 和一个目标值 ...

  • LeeCode刷题笔记

    1.两数之和 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数...

  • Leecode刷题笔记

    Mysql处理前几高的问题 最近刷了leecode几道题,发现有个哥们的写法很棒下面是为了自己找不到评论,所以引用...

  • 【学习】mysql学习

    20190528 一、数据分析深入浅出 二、mysql必知必会 三、leecode题库 刷leecode数据库题,...

  • leecode刷题(8)-- 两数之和

    leecode刷题(8)-- 两数之和 两数之和 描述: 给定一个整数数组 nums 和一个目标值 target,...

  • leecode刷题(3)-- 旋转数组

    leecode刷题(3)-- 旋转数组 旋转数组 给定一个数组,将数组中的元素向右移动 K 个位置,其中 K 是非...

  • leecode刷题(17)-- 实现StrStr

    leecode刷题(17)-- 实现StrStr 实现StrStr 描述: 实现 strStr() 函数。 给定一...

  • LeeCode刷题--Toeplitz Matrix

    题目 原题地址 A matrix is Toeplitz if every diagonal from top-l...

  • leecode刷题(18)-- 报数

    leecode刷题(18)-- 报数 报数 描述: 报数序列是一个整数序列,按照其中的整数的顺序进行报数,得到下一...

网友评论

    本文标题:leecode刷题(8)-- 移动零

    本文链接:https://www.haomeiwen.com/subject/mfhmdqtx.html