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

算法002——复写零

力扣——复写零点击即可跳转

在这里插入图片描述

这道题还是运用 双指针,我们从左往右开始,让 cur = 0,dest = 0,当我们循环时,会覆盖后面的值,所以从左到右无法实现,我们运用 从右到左的方式。

以示例一数组为例,从输出结果我们可以知道最后一个复写的数为 4,我们先让 cur 指向 4 的位置,让 dest 从数组的最后一个位置 从右往左 走

cur 会遇到两种情况

  • cur 指向的值为 非零元素
    此时,我们让 dest 指向的值 等于 cur 指向的值
    两个指针一起向前移动一位
  • cur 指向的值 为 零
    此时,我们将 dest 指向的值 和 dest 前一个位置的值 都改为 零

也就是说 cur 的位置为 0 时,dest 往前移动两位
在这里插入图片描述
下一步,找到 复写的最后一个数
还是使用双指针,dest 初始化为 -1 ,让 cur 从下标 0 开始遍历数组
此时 cur 有两种情况

  • cur 指向 非零
    dest 向右移动一位
  • cur 指向 零
    dest 向右移动两位

当 dest 指向最后的位置时,cur 所指向的位置就是 复写最后一个数

在这里插入图片描述
在 cur++ 前,我们要判断 dest 是否越界,当 cur 指向 零 时,而 dest 此时正在数组的最后一个位置,这个情况 dest 向右移动两位会越界。
当我们出现 越界 情况时, 此时一定是因为 cur 指向 零 导致的,此时我们将最后一个位置修改成 零 ,然后让 dest 向前移动两位, cur 向前移动一位,然后继续完成复写操作。

代码如下

class Solution {public void duplicateZeros(int[] arr) {//1.首先找到最后一个复写的数int cur = 0;int dest = -1;while(cur < arr.length){if(arr[cur] == 0){dest+=2;}else{dest++;}if(dest >= arr.length - 1){break;}cur++;}//2.处理边界,此时越界,越界情况只可能为0if(dest == arr.length){arr[arr.length - 1] = 0;dest-=2;cur--;}//3.从后向前完成复写操作while(cur >= 0){if(arr[cur] != 0){arr[dest] = arr[cur];dest--;cur--;}else{arr[dest] = 0;dest--;arr[dest]= 0;dest--;cur--;}}}
}

今天累成菜狗了,什么都没学到,起码累到了
在这里插入图片描述

http://www.lryc.cn/news/544732.html

相关文章:

  • 例子 DQN + CartPole: 深入思考一下,强化学习确实是一场智能冒险之旅!
  • java 实现xxl-job定时任务自动注册到调度中心
  • esp32串口通信
  • 蓝桥杯备赛-前缀和-可获得的最小取值
  • UniApp 中封装 HTTP 请求与 Token 管理(附Demo)
  • 边缘计算+多模态感知:户外监控核心技术解析与工程部署实践!户外摄像头监控哪种好?户外摄像头监控十大品牌!格行视精灵VS海康威视VS大华横评!
  • Spring项目-抽奖系统(实操项目)(ONE)
  • STM32-智能小车项目
  • Python:字符串常见操作
  • Redis 哈希(Hash)
  • Windows对比MacOS
  • react 路由跳转的几种方式
  • 2.你有什么绝活儿?—Java能做什么?
  • 2025年2月文章一览
  • C++ | 面向对象 | 类
  • leetcode:2164. 对奇偶下标分别排序(python3解法)
  • Visionpro cogToolBlockEditV2.Refresh()
  • Apache Spark中的依赖关系与任务调度机制解析
  • 网络基础III
  • 【SpringBoot】自动配置原理与自定义启动器
  • Element实现el-dialog弹框移动、全屏功能
  • Ubuntu 下 nginx-1.24.0 源码分析 - ngx_init_cycle 函数 - 详解(11)
  • 千峰React:案例一
  • 部署Joplin私有云服务器postgres版-docker compose
  • rust学习笔记6-数组练习704. 二分查找
  • Jsmoke-一款强大的js检测工具,浏览器部署即用,使用方便且高效
  • PyCharm中通过命令行执行`pip`命令下载到哪里了:虚拟环境目录下
  • Spring Boot操作MaxComputer(保姆级教程)
  • Spring的构造注入
  • 服务器IPMI用户名、密码批量检查