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

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

快慢指针

30min

java 复制代码
    public void moveZeroes(int[] nums) {
    int slowPoint = 0; // 慢指针,指向非零元素的位置
    // 遍历数组
    for (int fastPoint = 0; fastPoint < nums.length; fastPoint++) {
        if (nums[fastPoint] != 0) {
            // 交换慢指针和快指针的位置
            nums[slowPoint] = nums[fastPoint];
            slowPoint++;
        }
    }
    
    // 将剩余的位置填充为0
    for (int i = slowPoint; i < nums.length; i++) {
        nums[i] = 0;
    }
}
相关推荐
Billlly4 分钟前
ABC 453 个人题解
算法·题解·atcoder
玉树临风ives12 分钟前
atcoder ABC 452 题解
数据结构·算法
feifeigo12336 分钟前
基于马尔可夫随机场模型的SAR图像变化检测源码实现
算法
fengfuyao9851 小时前
基于STM32的4轴步进电机加减速控制工程源码(梯形加减速算法)
网络·stm32·算法
无敌昊哥战神2 小时前
深入理解 C 语言:巧妙利用“0地址”手写 offsetof 宏与内存对齐机制
c语言·数据结构·算法
小白菜又菜2 小时前
Leetcode 2075. Decode the Slanted Ciphertext
算法·leetcode·职场和发展
Proxy_ZZ02 小时前
用Matlab绘制BER曲线对比SPA与Min-Sum性能
人工智能·算法·机器学习
黎阳之光3 小时前
黎阳之光:以视频孪生领跑全球,赋能数字孪生水利智能监测新征程
大数据·人工智能·算法·安全·数字孪生
小李子呢02113 小时前
前端八股6---v-model双向绑定
前端·javascript·算法
2301_822703204 小时前
Flutter 框架跨平台鸿蒙开发 - 创意声音合成器应用
算法·flutter·华为·harmonyos·鸿蒙