【leetcode283】移动零

1、题目描述

题目链接

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

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

示例 1:

输入: nums = 0,1,0,3,12

输出: 1,3,12,0,0

示例 2:

输入: nums = 0

输出: 0

2、基本思路

 基本思想,将数组中不为零的数按照原来的顺序依次放到数组的前部分,将0元素放置到数组的后部分

双指针的思路,

  • 指针i用于遍历,指向待处理序列的头部,找出位置不为零的位置
  • 指针j指向当前已经处理好序列的尾部
  • 指针j的左边均非零,指针i到指针j之间均为0

 另外一种思路,将所有非0元素按顺序移动到数组前面,然后缺少几个零就补几个零。

3、代码实现

方法一

cpp 复制代码
void moveZeroes(vector<int>& nums) {
       

        for(int i =0,j=0;i<nums.size();++i)
        {
            if(nums[i])
            {
                swap(nums[i],nums[j]);
                j++;
            }
        }

    }

方法二

cpp 复制代码
void moveZeroes(vector<int>& nums) {
        
        int cnt= 0;//统计非零个数
        int k;
        for(k=0;k<nums.size();++k )
        {
            if(nums[k])
            {
                nums[cnt++] = nums[k];
            }
        }
        //补零
        while(nums.size()-cnt>0)
        {
            nums[cnt++] = 0;
        }
    }
相关推荐
Jerryhut1 分钟前
opencv对齐算法及其应用
人工智能·opencv·算法
果丁智能12 分钟前
智慧校园一卡通深度融合方案:基于超级SIM卡的手机碰一碰智能开锁技术落地实践
数据结构·人工智能·python·科技·算法·智能家居·信息与通信
满怀冰雪20 分钟前
第13篇-栈算法入门-括号匹配-表达式与单调栈基础
java·算法
Irissgwe23 分钟前
顺序表和链表
数据结构·c++·链表·c·顺序表·线性表
TCW112123 分钟前
AI底层系列:用C++实现线性代数的公式推导与算法设计-基础篇-5.矩阵方程
人工智能·线性代数·算法
叫我:松哥25 分钟前
基于机器学习和flask的体育健身风险智能分析系统,系统集成DeepSeek、聚类算法、分类算法等,准确率达90%
人工智能·python·神经网络·算法·机器学习·flask·聚类
wabs66628 分钟前
关于动态规划【0-1背包思想在实际问题中是怎么转化的?】
算法·动态规划
阿文的代码库30 分钟前
欧拉回路与欧拉路径的算法流程演示
算法
汤姆yu36 分钟前
云知声 U2 原生智能体大模型深度解析
大数据·人工智能·算法·ai·大模型·多模态·智能体
小糯米60138 分钟前
C语言文件操作
c语言·开发语言·数据结构