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

27. 移除元素

给你一个数组nums和一个值val,你需要原地移除所有数值等于val的元素。元素的顺序可能发生改变。然后返回nums中与val不同的元素的数量。

假设nums中不等于val的元素数量为k,要通过此题,您需要执行以下操作:

  • 更改nums数组,使nums的前k个元素包含不等于val的元素。nums的其余元素和nums的大小并不重要。
  • 返回k

思路:

由于题目要求删除数组中等于val的元素,因此输出数组的长度一定小于等于输入数组的长度,我们可以把输出的数组覆盖在输入数组上。

可以使用双指针:

右指针left指向当前将要处理的元素

左指针lens指向下一个将要复制的位置。

如果右指针left指向的元素不等于val,它一定是输出数组的一个元素,我们就将右指针left指向的元素复制到左指针lens位置,然后将左指针lens和右指针left同时右移;

如果右指针left指向的元素等于val,它不能出现在输出数组里,此时左指针lens不动,右指针left右移一位。

整个过程保持不变的性质是:区间[0, lens)中的元素都不等于val。当左右指针遍历完输入数组以后,lens的值就是输出数组的长度。


class Solution(object): def removeElement(self, nums, val): lens=0 for left in range(len(nums)): if nums[left] != val: nums[lens] = nums[left] lens+=1 return lens

int removeElement(int* nums, int numsSize, int val) { int lens=0; int left; for(left=0;left<numsSize;left++) { if(nums[left]!=val) nums[lens++]=nums[left]; } return lens; }
http://www.jsqmd.com/news/472886/

相关文章:

  • 李哥深度学习班学习笔记——图像识别
  • AI Agent时代来临:Cursor、Claude Code重构开发者生态
  • 石墨烯/钙钛矿太阳能电池COMSOL仿真:文献复现光电耦合模型
  • 京东社招——Java后端开发面试复盘
  • 面向强随机性场景的短期净负荷功率预测:基于集成学习的元学习器设计
  • 勒索病毒专盯数据库? TDE 透明加密如何筑起“最后一道防线
  • Linuex操作系统的优化
  • 分库分表(一)
  • vmd分解联合小波阈值降噪MATLAB代码。具体实现功能如下: 1.数据加载与预处理 数据从CSV文件读取并转换为数组,处理了多列数据的情况。 采样频率 Fs 设置为1000 Hz,这是后续时频分析的
  • PID算法(3)- PID就是求【针对控制量的一个比例+积分+微分】的值
  • 复现论文:基于动力学Wulff图理解和控制异质外延——以GaN为例
  • 类与对象说人话
  • K-Means聚类算法的数据可视化与综合分析:从原理到实践的完整指南
  • Agent-Browser 简明教程
  • 多智能体事件触发一致性
  • SQL 客户端远程登录服务器详细操作教程
  • 6 个动作锻炼核心肌群,让你的腰力更强!
  • 再斩国际设计大奖!玛吉斯VS6、HP6荣获2026德国iF设计奖
  • 多相流模拟在含裂缝非均质地层中的数值计算研究——基于间断伽辽金方法的探索
  • 2026年如何查看AI关键词排名?品牌在AI回答中的排序一键测
  • nginx的核心功能
  • 智能体赋能的企业运营分析与决策支持系统:从认知架构到自动化闭环
  • MVI56-BAS通讯模块
  • 企业微信外部客户群自动化管理:建群+群发+踢人一体化
  • gdb基础操作
  • 基于自适应PI的构网型变流器预同步控制策略复现报告
  • 实验室纯水机怎么选?2026 纯水系统品牌及选型全攻略
  • Claude Code Task 系统:任务管理与进度追踪
  • 液压挖掘机主机厂整机CAD图纸
  • 膜结构车棚性价比排名深度解析