【暴刷力扣】283. 移动零

283. 移动零

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

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

示例 1:

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

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

示例 2:

输入: nums = [0]

输出: [0]

提示:

1 <= nums.length <= 104

-231 <= nums[i] <= 231 - 1

进阶:你能尽量减少完成的操作次数吗?

代码

js 复制代码
var moveZeroes = function(nums) {
   let slow = 0, fast = 0
   for (;fast < nums.length; slow++, fast ++) {
    if (nums[slow] === 0) {
        while (nums[fast] === 0) {
            fast ++
        }
        if (nums[fast]) {
            [nums[fast], nums[slow]] = [nums[slow], nums[fast]]
        }
    }
   }
   return nums
};
相关推荐
TracyCoder1237 小时前
LeetCode Hot100(15/100)——54. 螺旋矩阵
算法·leetcode·矩阵
u0109272718 小时前
C++中的策略模式变体
开发语言·c++·算法
2501_941837268 小时前
停车场车辆检测与识别系统-YOLOv26算法改进与应用分析
算法·yolo
探序基因9 小时前
单细胞Seurat数据结构修改分群信息
数据结构
六义义10 小时前
java基础十二
java·数据结构·算法
四维碎片10 小时前
QSettings + INI 笔记
笔记·qt·算法
Tansmjs10 小时前
C++与GPU计算(CUDA)
开发语言·c++·算法
独自破碎E10 小时前
【优先级队列】主持人调度(二)
算法
weixin_4454766811 小时前
leetCode每日一题——边反转的最小成本
算法·leetcode·职场和发展
打工的小王11 小时前
LeetCode Hot100(一)二分查找
算法·leetcode·职场和发展