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++

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

相关推荐
灵感__idea5 小时前
Hello 算法:“走一步看一步”的智慧
前端·javascript·算法
lwf0061646 小时前
导数学习日记
学习·算法·机器学习
头发够用的程序员7 小时前
从滑动窗口到矩阵运算:img2col算法基本原理
人工智能·算法·yolo·性能优化·矩阵·边缘计算·jetson
武帝为此7 小时前
【数据清洗缺失值处理】
python·算法·数学建模
Halo_tjn8 小时前
Java 基于字符串相关知识点
java·开发语言·算法
念越8 小时前
算法每日一题 Day08|双指针法解决三数之和
算法·力扣
黎阳之光9 小时前
黎阳之光透明管理:视频孪生重构智慧仓储新范式
人工智能·算法·安全·重构·数字孪生
6Hzlia9 小时前
【Hot 100 刷题计划】 LeetCode 199. 二叉树的右视图 | C++ DFS 逆序遍历
c++·leetcode·深度优先
CappuccinoRose10 小时前
回溯法 - 软考备战(四十三)
算法·排列组合·路径·n皇后·子集·解数独·岛屿
AC赳赳老秦10 小时前
OpenClaw进阶技巧:批量修改文件内容、替换关键词,解放双手
java·linux·人工智能·python·算法·测试用例·openclaw