LeetCode - 283 - 移动零(move-zeroes)

Create by jsliang on 2019-07-19 14:19:24
Recently revised in 2019-07-19 15:15:12

一 目录

不折腾的前端,和咸鱼有什么区别

| 目录 | | --- | | 一 目录 | | 二 前言 | | 三 解题 | |  3.1 解法 - 暴力破解 | |  3.2 解法 - 冒泡排序 |

二 前言

  • 难度:简单

  • 涉及知识:数组、双指针

  • 题目地址:https://leetcode-cn.com/problems/move-zeroes/

  • 题目内容

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。	
示例:	
输入: [0,1,0,3,12]	
输出: [1,3,12,0,0]	
说明:	
必须在原数组上操作,不能拷贝额外的数组。	
尽量减少操作次数。

三 解题

小伙伴可以先自己在本地尝试解题,再回来看看 jsliang 的解题思路。

3.1 解法 - 暴力破解

  • 解题代码

var moveZeroes = function(nums) {	
  let map = new Map();	
  map.set(0, 0);	
  for (let i = 0; i < nums.length; i++) {	
    if (nums[i] === 0) {	
      nums.splice(i, 1);	
      map.set(0, map.get(0) + 1);	
      i--;	
    }	
  }	
  for (let i = 0; i < map.get(0); i++) {	
    nums.push(0);	
  }	
  return nums;	
};
  • 执行测试

  1. nums: [0,1,0,3,12]

  2. return: [1,3,12,0,0]

  • LeetCode Submit

✔ Accepted	
  ✔ 21/21 cases passed (100 ms)	
  ✔ Your runtime beats 64.67 % of javascript submissions	
  ✔ Your memory usage beats 55.1 % of javascript submissions (35.6 MB)
  • 知识点

  1. Map:保存键值对。任何值(对象或者原始值) 都可以作为一个键或一个值。 Map 详细介绍

  2. splice(): splice() 方法通过删除或替换现有元素或者原地添加新的元素来修改数组,并以数组形式返回被修改的内容。此方法会改变原数组。 splice() 详细介绍

  3. push(): push() 方法将一个或多个元素添加到数组的末尾,并返回该数组的新长度。 push() 详细介绍

  • 解题思路

首先,记住一点,它要求在原数组操作,不得逾越。

然后,我们的思路就是:

  1. 使用 Map 来记录 0 出现的次数。

  2. 使用 splice() 来切割原数组。

  3. 判断 Map 中 0 出现的次数,将 0 push 进数组。

最后,我们可以返回数组,也可以不返回数组,结束这道题题解。

  • 进一步思考

这代码可不可以优化呢?

var moveZeroes = function(nums) {	
  let count = [];	
  for (let i = 0; i < nums.length; i++) {	
    if (nums[i] === 0) {	
      nums.splice(i, 1);	
      count.push(0);	
      i--;	
    }	
  }	
  nums.push(...count);	
  return nums;	
};

Submit 提交结果为:

✔ Accepted	
  ✔ 21/21 cases passed (80 ms)	
  ✔ Your runtime beats 97.1 % of javascript submissions	
  ✔ Your memory usage beats 44.37 % of javascript submissions (35.7 MB)

3.2 解法 - 冒泡排序

  • 解题代码

var moveZeroes = function (nums) {	
  for (let i = 0; i < nums.length; i++) {	
    for (let j = 0; j < nums.length - i - 1; j++) {	
      if (nums[j + 1] !== 0 && nums[j] === 0) {	
        nums[j] = nums[j + 1];	
        nums[j + 1] = 0;	
      }	
    }	
  }	
  return nums;	
}
  • 执行测试

  1. nums: [0,1,0,3,12]

  2. return: [1,3,12,0,0]

  • LeetCode Submit

✔ Accepted	
  ✔ 21/21 cases passed (272 ms)	
  ✔ Your runtime beats 6.17 % of javascript submissions	
  ✔ Your memory usage beats 34.33 % of javascript submissions (35.7 MB)
  • 解题思路

一种效率低下但仍不失为解决方案之一的方法

冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法。

它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果他们的顺序(如从大到小、首字母从 A 到 Z)错误就把他们交换过来。走访元素的工作是重复地进行直到没有相邻元素需要交换,也就是说该元素列已经排序完成。

在本题中:

if (nums[j + 1] !== 0 && nums[j] === 0) {	
  nums[j] = nums[j + 1];	
  nums[j + 1] = 0;	
}

如果当前的数字为 0,且它后面的那个数字不为 0,则把这个 0 往后移。

直到 0 都移动到了后面为止。


不折腾的前端,和咸鱼有什么区别!

640?wx_fmt=jpeg

jsliang 会每天更新一道 LeetCode 题解,从而帮助小伙伴们夯实原生 JS 基础,了解与学习算法与数据结构。

扫描上方二维码,关注 jsliang 的公众号,让我们一起折腾!

640?wx_fmt=png

jsliang 的文档库 由 梁峻荣 采用 知识共享 署名-非商业性使用-相同方式共享 4.0 国际 许可协议进行许可。
基于https://github.com/LiangJunrong/document-library上的作品创作。
本许可协议授权之外的使用权限可以从 https://creativecommons.org/licenses/by-nc-sa/2.5/cn/ 处获得。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值