leetcode 283. 移动零

代码:

java 复制代码
class Solution {
    public void swap(int[] nums,int m,int n){
        int tmp=nums[m];
        nums[m]=nums[n];
        nums[n]=tmp;
    }
    public void moveZeroes(int[] nums) {
        int cur=0;
        int dest=-1;
        int n=nums.length;

        for(;cur<n;cur++){
            if(nums[cur]!=0){
                dest++;
                swap(nums,cur,dest);
            }
        }
    }
}

题解:

根据题意,我们要将数组进行处理,分为 非0 的区间和 全为0 的区间

现在我们通过 cur 指针遍历数组并按相关规则对数据进行处理,遍历过的区间是 已处理 区间,还未遍历的区间是未处理区间,而 已处理 区间中又分为 非0 的区间和 全为0 的区间,我们设定 dest 指针指向最后一个非0数据

这样划分,当 cur 指针遍历完数组以后,数组就被 dest 指针划分成了题意中左边为非 0 元素,右边为 0 的结构

现在我们根据题目所给的示例来介绍大致流程

我们向方法中传入了数组 nums=[0,1,0,3,12]

我们让 cur 指针(并不是真的指针,方便理解才这样说)指向下标 0,用来遍历数组,dest 指针指向下标 -1 ,因为 dest 指针的含义是指向最后一个非 0 数据,而现在 cur 指针还没有遍历到非 0 数据,所以先指向 -1

cur 指针向后遍历的时候会遇到两种情况:

1.cur 指针遇到 0

根据上面的图以及分析,我们知道,0 应该在指针 dest 和 cur 之间,所以我们得出,当 nums[cur]==0 --> cur++;

2.cur 指针遇到非 0 数据

由于 dest 指针要指向最后一个非 0 数据,所以 dest 首先要 ++,为该非 0 数据提供一个空位,此时 dest 指针指向的是 0 数据,cur 指针指向的是非 0 的数据,于是将 cur 和 dest 指针指向的数据进行交换

我们得到关系,当 nums[cur]!=0 --> dest++ , swap(nums[cur],nums[dest]) , cur++

根据两种情况得到的关系,编写代码即可

相关推荐
暮冬-  Gentle°4 小时前
C++中的命令模式实战
开发语言·c++·算法
卷福同学6 小时前
【养虾日记】Openclaw操作浏览器自动化发文
人工智能·后端·算法
春日见6 小时前
如何入门端到端自动驾驶?
linux·人工智能·算法·机器学习·自动驾驶
图图的点云库7 小时前
高斯滤波实现算法
c++·算法·最小二乘法
rainbow7242447 小时前
AI人才简历评估选型:技术面试、代码评审与项目复盘的综合运用方案
人工智能·面试·职场和发展
一叶落4387 小时前
题目:15. 三数之和
c语言·数据结构·算法·leetcode
努力学算法的蒟蒻8 小时前
day115(3.17)——leetcode面试经典150
面试·职场和发展
老鱼说AI8 小时前
CUDA架构与高性能程序设计:异构数据并行计算
开发语言·c++·人工智能·算法·架构·cuda
罗湖老棍子9 小时前
【例 1】数列操作(信息学奥赛一本通- P1535)
数据结构·算法·树状数组·单点修改 区间查询
big_rabbit05029 小时前
[算法][力扣222]完全二叉树的节点个数
数据结构·算法·leetcode