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++;
    }
}
相关推荐
naruto_lnq5 分钟前
C++与自动驾驶系统
开发语言·c++·算法
啊阿狸不会拉杆10 分钟前
《数字信号处理》第6章:数字滤波器的基本概念及几种特殊滤波器
算法·matlab·信号处理·数字信号处理·dsp
奶茶树14 分钟前
【数据结构进阶】AVL树(详解)
数据结构·c++
放荡不羁的野指针21 分钟前
leetcode150题-双指针
数据结构·算法·leetcode
面条有点辣22 分钟前
C++内存管理基础概念入门到理解
c++
蒹葭玉树25 分钟前
【C++上岸】C++常见面试题目--网络篇(第二十六期)
网络·c++·面试
老四啊laosi32 分钟前
[C++初阶] 10. string模拟实现
c++·stl·string
好学且牛逼的马35 分钟前
【Hot100|15-LeetCode 238. 除自身以外数组的乘积】
数据结构·算法·leetcode
Tisfy1 小时前
LeetCode 3651.带传送的最小路径成本:动态规划
算法·leetcode·动态规划·题解·排序
EmbedLinX1 小时前
C++ STL 学习笔记
c++·stl