X

LEETCODE 283. Move Zeroes 解题思路分析

题目大意:

移动零

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

示例:

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

说明:

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

如果想查看本题目是哪家公司的面试题,请参考以下免费链接: https://leetcode.jp/problemdetail.php?id=283

解题思路分析:

由于题目要求使用原地算法,因此本题的难度稍微有所提高。核心逻辑是,我们首先确定首个0的位置indexZero,在indexZero之前的元素都无须改变位置。indexZero后面第一个出现的非0数字,它的位置要前移至indexZero,而该数字原先的位置须设置为0,同时因为indexZero位置已不再是0,它的下标应该加一。重复上述过程,直到循环完所有数字为止。本题时间复杂度为O(n),空间复杂度为O(1)。

实现代码:

public void moveZeroes(int[] nums) {
    int firstZero=-1; // 首个0出现的位置,默认是-1,代表还没找到0
    for(int i=0;i<nums.length;i++){
        // 如果当前数字是0
        if(nums[i]==0){
            // 如果还没找到首个数字0,那么当前位置即是首个0的位置
            if(firstZero==-1) firstZero=i;
            continue;
        }
        // 当前数字不是0的情况
        // 如果还没发现数字0,当前数字不需要移动位置
        // 如果已经发现首个数字0的位置
        if(firstZero!=-1){
            // 将首个数字0的位置替换为当前数字
            nums[firstZero]=nums[i];
            // 当前位置置换为0
            nums[i]=0;
            // 首个数字0的位置加一
            firstZero++;
        }
    }
}

本题解法执行时间为0ms。

Runtime: 0 ms, faster than 100.00% of Java online submissions for Move Zeroes.

Memory Usage: 39.4 MB, less than 43.36% of Java online submissions for Move Zeroes.

本网站文章均为原创内容,并可随意转载,但请标明本文链接
如有任何疑问可在文章底部留言。为了防止恶意评论,本博客现已开启留言审核功能。但是博主会在后台第一时间看到您的留言,并会在第一时间对您的留言进行回复!欢迎交流!
本文链接: http://leetcode.jp/leetcode-283-move-zeroes-解题思路分析/
Categories: leetcode
kwantong: