当前位置: 首页 > article >正文

leetcode 283. 移动零

代码:

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

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

        

        

        


http://www.kler.cn/a/150029.html

相关文章:

  • 模拟实现string类
  • 2.3.3 数据类型的转换与强制类型转换
  • AI大模型:DeepSeek
  • Linux 基础命令
  • JAVA_内部类
  • 全栈开发:使用.NET Core WebAPI构建前后端分离的核心技巧(二)
  • JavaScript基础知识总结
  • Java 关于批量插入遇到的问题 -sqlserver
  • 配置阿里云的yum仓库
  • qt-C++笔记之主线程中使用异步逻辑来处理ROS事件循环和Qt事件循环解决相互阻塞的问题
  • 数学加速器:Python numpy.add函数全解读
  • 基于单片机的肺活量检测系统(论文+源码)
  • 树与二叉树堆:堆的意义
  • SpringBoot整合EasyExcel实现复杂Excel表格的导入导出功能
  • DNS/ICMP协议、NAT技术
  • goweb入门教程
  • Python dns域名解析(dns.resolver)
  • 【LeetCode:1670. 设计前中后队列 | 数据结构设计】
  • spring-webflux的一些概念的理解
  • 【Rust】基本的语法概念
  • 唯创知音WT588F02B-8S语音芯片:灵活更换语音内容,降低开发成本与备货压力
  • python每日一题——12最小覆盖子串
  • GoLang切片
  • Leetcode算法系列| 1. 两数之和(四种解法)
  • OpenLDAP配置web管理界面PhpLDAPAdmin服务-centos9stream
  • Spring---对象的存储和读取