博客
关于我
数组去去零,同一列表操作数值删除添加
阅读量:307 次
发布时间:2019-03-03

本文共 673 字,大约阅读时间需要 2 分钟。

要将数组中的所有零移动到末尾,同时保持非零元素的相对顺序,可以采用以下方法:

方法一:从后往前遍历

这个方法的核心思想是从数组的末尾开始遍历,遇到零时将其移动到末尾。这种方法避免了因删除元素导致索引变化的问题,从而保证了非零元素的相对顺序。

代码实现

nums = [0, 1, 0, 3, 12]for i in range(len(nums)-1, -1, -1):    if nums[i] == 0:        nums.append(nums[i])        nums.pop(i)print(nums)  # 输出: [1, 3, 12, 0, 0]

方法二:使用变量记录零的位置

另一种方法是使用一个变量来记录零的位置。当遇到非零元素时,将其移到记录位置后面,然后将零移动到末尾。

代码实现

nums = [0, 1, 0, 3, 12]j = 0for i in range(len(nums)):    if nums[i] == 0:        nums.append(nums[i])        nums.pop(i)    else:        j += 1print(nums)  # 输出: [1, 3, 12, 0, 0]

示例验证

输入:[0, 1, 0, 3, 12]

  • 方法一:经过两次移动,零移动到末尾,输出为 [1, 3, 12, 0, 0]
  • 方法二:同样经过两次移动,零移动到末尾,输出为 [1, 3, 12, 0, 0]

这两种方法都能高效地解决问题,且在操作次数上表现优异。

转载地址:http://woml.baihongyu.com/

你可能感兴趣的文章
MySQL集群解决方案(4):负载均衡
查看>>
MySQL高级-视图
查看>>
nacos集群搭建
查看>>
Navicat for MySQL 查看BLOB字段内容
查看>>
Neo4j的安装与使用
查看>>
Neo4j(2):环境搭建
查看>>
nessus快速安装使用指南(非常详细)零基础入门到精通,收藏这一篇就够了
查看>>
Nessus漏洞扫描教程之配置Nessus
查看>>
Nest.js 6.0.0 正式版发布,基于 TypeScript 的 Node.js 框架
查看>>
Netpas:不一样的SD-WAN+ 保障网络通讯品质
查看>>
netsh advfirewall
查看>>
Netty WebSocket客户端
查看>>
Netty 异步任务调度与异步线程池
查看>>
Netty中集成Protobuf实现Java对象数据传递
查看>>
Netty工作笔记0006---NIO的Buffer说明
查看>>
Netty工作笔记0011---Channel应用案例2
查看>>
Netty工作笔记0013---Channel应用案例4Copy图片
查看>>
Netty工作笔记0014---Buffer类型化和只读
查看>>
Netty工作笔记0020---Selectionkey在NIO体系
查看>>
Vue踩坑笔记 - 关于vue静态资源引入的问题
查看>>