4.移动零

1.题目描述

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

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

示例 1:

复制代码
输入: nums = [0,1,0,3,12]
输出: [1,3,12,0,0]

2.解题思路

思路1:暴力解,循环过程中记录0的个数,遇到非0就往前移动0个数个位置(新手友好型),最后再填补0到末尾

思路2:双指针遍历+交换

3.代码

1)暴力法

cpp 复制代码
void moveZeroes(int* nums, int numsSize) {

    int cnt = 0;//记录0的个数
    for(int i = 0; i < numsSize; i++){
        if(nums[i]==0){
            cnt++;//碰到0就+1
        }else{//否则就移动非零元素
             nums[i-cnt] = nums[i];
        }
    }
    for(int j = 0; j< cnt;j++){
        nums[numsSize -1- j] = 0;//填补0
    }
}

2)双指针法

cpp 复制代码
void swap(int *a, int *b) {
    int t = *a;
    *a = *b, *b = t;
}

void moveZeroes(int *nums, int numsSize) {
    int left = 0, right = 0;
    while (right < numsSize) {
        if (nums[right]) {
            swap(nums + left, nums + right);
            left++;
        }
        right++;
    }
}
相关推荐
姓蔡小朋友3 小时前
算法-滑动窗口
算法
君义_noip3 小时前
信息学奥赛一本通 2134:【25CSPS提高组】道路修复 | 洛谷 P14362 [CSP-S 2025] 道路修复
c++·算法·图论·信息学奥赛·csp-s
kaikaile19954 小时前
基于拥挤距离的多目标粒子群优化算法(MO-PSO-CD)详解
数据结构·算法
liulilittle4 小时前
OPENPPP2 Code Analysis One
网络·c++·网络协议·信息与通信·通信
不忘不弃4 小时前
求两组数的平均值
数据结构·算法
leaves falling4 小时前
迭代实现 斐波那契数列
数据结构·算法
珂朵莉MM4 小时前
全球校园人工智能算法精英大赛-产业命题赛-算法巅峰赛 2025年度画像
java·人工智能·算法·机器人
Morwit4 小时前
*【力扣hot100】 647. 回文子串
c++·算法·leetcode
天赐学c语言4 小时前
1.7 - 删除排序链表中的重要元素II && 哈希冲突常用解决冲突方法
数据结构·c++·链表·哈希算法·leecode
w陆压4 小时前
12.STL容器基础
c++·c++基础知识