【暴刷力扣】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
};
相关推荐
黎阳之光几秒前
黎阳之光:以视频孪生硬核实力,抢抓交通科技新机遇
大数据·人工智能·算法·安全·数字孪生
WL_Aurora3 分钟前
2026天梯赛题解
python·算法
Engineer邓祥浩7 分钟前
知识点1 时间复杂度、空间复杂度
java·数据结构·算法
博界IT精灵13 分钟前
森林和二叉树的转换(哈喜老师)
数据结构
啊我不会诶16 分钟前
Codeforces Round 1093 (Div. 2)vp补题
算法
算法即正义17 分钟前
知识竞赛音乐推荐:从开场抢答到颁奖环节的背景音乐选择指南
算法·职场和发展·学习方法
RTC老炮24 分钟前
音视频FEC前向纠错算法Reed-Solomon原理分析
网络·算法·架构·音视频·webrtc
噜噜噜噜鲁先森28 分钟前
STL——String类
开发语言·c++·算法
Severus_black29 分钟前
算法题C——用队列实现栈/用栈实现队列
c语言·数据结构·算法·链表
谭欣辰33 分钟前
详细讲解 C++ 有向无环图(DAG)及拓扑排序
c++·算法·图论