双指针-力扣hot100-移动零.283

可以用「双指针」一次遍历,时间复杂度 O(n)、空间复杂度 O(1),满足原地修改和保持相对顺序的要求。

思路:

  • 用一个指针 slow 指向当前应该放"下一个非零元素"的位置。

  • 用另一个指针 fast 从头到尾遍历数组:

    • 每当 nums[fast] != 0,就把该非零元素放到 nums[slow],然后 slow++
  • 第一遍结束后,slow 之前的元素都是按原顺序排好的非零元素。

  • 接下来从 slow 到数组末尾全部填 0 即可。

这样能保证:

  • 所有非零元素的相对顺序不变(因为我们按原顺序从左到右拷贝过去)。

  • 0 都被集中到末尾。

  • 原地操作,只使用了常数额外空间。

代码实现(C++)

复制代码
class Solution {
public:
    void moveZeroes(vector<int>& nums) {
        int n = nums.size();
        int slow = 0; // 指向下一个应该放非零元素的位置

        // 1. 把所有非零元素按原顺序移动到前面
        for (int fast = 0; fast < n; ++fast) {
            if (nums[fast] != 0) {
                nums[slow] = nums[fast];
                ++slow;
            }
        }

        // 2. slow 之后填充为 0
        while (slow < n) {
            nums[slow] = 0;
            ++slow;
        }
    }
};
复杂度分析
  • 时间复杂度:O(n),只遍历了一次数组,再加一次填 0。

  • 空间复杂度:O(1),未使用额外数组,原地修改。

相关推荐
汀、人工智能5 分钟前
[特殊字符] 第77课:最长递增子序列
数据结构·算法·数据库架构·图论·bfs·最长递增子序列
网域小星球5 分钟前
C语言从0入门(十)|二维数组详解与矩阵实战
c语言·算法·矩阵·二维数组·数组遍历
澈20711 分钟前
堆排序:高效构建大顶堆实战
数据结构·算法·排序算法
我真不是小鱼33 分钟前
cpp刷题打卡记录27——无重复字符的最长子串 & 找到字符串中所有字母的异位词
数据结构·c++·算法·leetcode
XuecWu338 分钟前
原生多模态颠覆Scaling Law?解读语言“参数需求型”与视觉“数据需求型”核心差异
人工智能·深度学习·算法·计算机视觉·语言模型
We་ct38 分钟前
LeetCode 69. x 的平方根:两种解法详解
前端·javascript·算法·leetcode·typescript·平方
一直不明飞行40 分钟前
C++:string,写法s.find(‘@‘) != s.end()是否有问题
开发语言·c++·算法
Proxy_ZZ01 小时前
打造自己的信道编码工具箱——Turbo、LDPC、极化码三合一
c语言·算法·信息与通信
wayz111 小时前
21天机器学习核心算法学习计划(量化方向)
学习·算法·机器学习
穿条秋裤到处跑1 小时前
每日一道leetcode(2026.04.09):区间乘法查询后的异或 II
算法·leetcode