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

【双指针_移动零_C++】

题目解析
移动零

nums = [0,1,0,3,12]
[1,3,12,0,0]

算法原理
数组划分(数组分块)

双指针算法(利用数组下标来充当指针)

使用两个指针的作用:

cur指针:从左往右扫描数组,就是遍历数组。
dest指针:已经处理之后的区间内,非零元素的最后一个位置

这两个指针将分隔为三个区间:

第一个:[0,dest]
第二个:[dest+1,cur-1]
第三个:[cur,n-1]

在这里插入图片描述

第一个:[0,dest] 非0元素
第二个:[dest+1,cur-1] 0元素
第三个:[cur,n-1] 未处理元素

在这里插入图片描述


[0,1,0,3,12]

在这里插入图片描述

当你遇到0元素的时候,只需要让cur向后移动一位即可
当你遇到非0元素的时候,需要让dest先去向后移动一位,然后交换dest与cur位置的元素,然后cur继续向后移动一位。

在这里插入图片描述
在这里插入图片描述

当cur遍历到n位置的时候,表示已经完成。

在这里插入图片描述
总结一下:

cur从前往后遍历的过程中,会有两种情况:1.遇到0元素:cur++2.遇到非0元素:swap(dest+1,cur)dest++,cur++

编写代码

class Solution {
public:void moveZeroes(vector<int>& nums) {for(int cur = 0,dest = -1;cur<nums.size();cur++){if(nums[cur]!=0){swap(nums[++dest],nums[cur]);}}}
};
http://www.lryc.cn/news/107688.html

相关文章:

  • 【网络安全】网络安全威胁实时地图 - 2023
  • 视频过大如何压缩变小?文件压缩技巧分享
  • 组合模式(Composite)
  • grid map学习笔记3之详解grid_map_pcl库实现point cloud点云转换成grid map栅格地图
  • ebpf开发问题汇总
  • 认识 mysql 命令
  • IK(Inverse Kinematics,逆运动学)
  • Cadence 小技巧系列(持续更新)
  • 【unity】Pico VR 开发笔记(基础篇)
  • 竞争之王CEO商战课,聚百家企业在京举行
  • 【shell】获取ping的时延数据并分析网络情况及常用命令学习
  • 石子合并一章通(环形石子合并,四边形不等式,GarsiaWachs算法)(内附封面)
  • Docker快速入门笔记
  • 【Excel】记录Match和Index函数的用法
  • SolidUI社区-从开源社区角度思考苹果下架多款ChatGPT应用
  • 插入排序讲解
  • 杀疯了的ChatGPT——开启AI智能交流新纪元 「文末有彩蛋」
  • web爬虫第五弹 - JS逆向入门(猿人学第一题)
  • P5731 【深基5.习6】蛇形方阵
  • Python实现GA遗传算法优化循环神经网络回归模型(LSTM回归算法)项目实战
  • ESD防静电监控系统在SMT产线中的应用案例
  • Vue+Nodejs+Express+Minio 实现本地图片上传
  • em3288 linux_4.19 第一次烧写无法进入内核的情况
  • 【Java多线程学习5】什么是悲观锁,什么是乐观锁?如何实现乐观锁、乐观锁存在哪些问题
  • OSPF协议RIP协议+OSPF实验(eNSP)
  • leetcode每日一练-第108题-将有序数组转换为二叉搜索树
  • 王道《操作系统》学习(二)—— 进程管理(二)
  • Vulnhub: shenron: 3靶机
  • Kubernetes高可用集群二进制部署(二)ETCD集群部署
  • mysql主从复制及原理