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

优选算法:移动零

题目链接

移动零

 

题目描述

 

核心思路

使用双指针法,通过两个指针(prev 和 cur)的配合,高效完成零元素的移动,时间复杂度为 O(n)(n 是数组长度),空间复杂度为 O(1)(仅使用常数级额外空间)。

  • cur:遍历指针,负责从头到尾扫描整个数组。
  • prev:记录非零元素的「待放置位置」,始终指向已处理部分的最后一个非零元素(初始化为 -1,表示尚未遇到非零元素)。

代码执行步骤

  1. 初始化指针cur = 0(从数组第一个元素开始遍历),prev = -1(初始无有效非零元素)。
  2. 遍历数组cur 从 0 到 nums.size() - 1 逐个移动:
    • 若 nums[cur] 是非零元素(if(nums[cur]),等价于 if(nums[cur] != 0)):
      • 先将 prev 向前移动一位(++prev),此时 prev 指向「下一个非零元素的放置位置」。
      • 交换 nums[prev] 和 nums[cur]:将当前非零元素 nums[cur] 放到 prev 位置,而原 prev 位置的元素(可能是零,也可能是之前未处理的非零元素)被交换到 cur 位置。
    • 若 nums[cur] 是零元素:不做操作,cur 继续向后移动。
  3. 遍历结束:所有非零元素已通过交换移动到数组前端,且保持相对顺序;零元素自然被「挤到」数组末尾。

示例演示

以数组 nums = [0, 1, 0, 3, 12] 为例,模拟执行过程:

步骤curnums[cur]prev操作(交换后数组)
100-1不操作,cur++
211(非零)-1 → 0交换 nums [0] 和 nums [1] → [1,0,0,3,12]
3200不操作,cur++
433(非零)0 → 1交换 nums [1] 和 nums [3] → [1,3,0,0,12]
5412(非零)1 → 2交换 nums [2] 和 nums [4] → [1,3,12,0,0]

最终结果:[1, 3, 12, 0, 0],符合预期。 

关键细节

  • 非零元素相对顺序不变:由于 cur 按顺序遍历,且每次交换都是将「当前非零元素」放到「前一个非零元素的下一位」,因此非零元素的相对顺序不会被破坏。
  • 交换的意义:当 prev 和 cur 不相等时,交换会将非零元素前移;当 prev == cur(如数组开头就是非零元素),交换相当于无操作,不影响结果。

 完整代码:

 

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

相关文章:

  • 使用ffmpeg转码h265后mac默认播放器不支持问题
  • Mac电脑使用IDEA启动服务后,报service异常
  • 从零构建 Node20+pnpm+pm2 环境镜像:基于 Dockerfile 的两种方案及持久化配置指南
  • 开源Qwen凌晨暴击闭源Claude!刷新AI编程SOTA,支持1M上下文
  • Vue3实现视频播放弹窗组件,支持全屏播放,音量控制,进度条自定义样式,适配浏览器小窗播放,视频大小自适配,缓冲loading,代码复制即用
  • 合泰单片机怎么样
  • idea监控本地堆栈
  • Linux系统监控模块之Zabbix7添加监控主机
  • 生成式人工智能展望报告-欧盟-03-经济影响
  • 第一二章笔记
  • 同步时钟系统提升仓库自动化水平
  • Opentrons 模块化平台与AI技术助力智能移液创新,赋能AAW™自动化工作站
  • 爬虫逆向--Day12--DrissionPage案例分析【小某书评价数据某东评价数据】
  • 2025年区块链安全威胁全景:新兴漏洞、攻击向量与防护策略深度解析
  • 常见半导体的介电常数
  • gitlab使用 备份恢复 全量迁移
  • 期货交易系统界面功能与操作流程解析
  • C++ <多态>详解:从概念到底层实现
  • Java 实现 B/S 架构详解:从基础到实战,彻底掌握浏览器/服务器编程
  • 深入理解 ThreadLocal:从原理到最佳实践
  • LLM层归一化:γβ与均值方差的协同奥秘
  • MySQL--day13--视图存储过程与函数
  • 【小董谈前端】【样式】 CSS与样式库:从实现工具到设计思维的跨越
  • 大数据集分页优化:LIMIT OFFSET的替代方案
  • MySQL数据库迁移至国产数据库测试案例
  • multiprocessing模块使用方法(二)
  • 微信格式插件 建的文件位置
  • 负载均衡-LoadBalance
  • 机器学习基础-k 近邻算法(从辨别水果开始)
  • TCP重传率优化在云服务器网络协议栈的调优实践