力扣26:删除有序数组中的重复项

news/2025/2/12 16:08:53/

26. 删除有序数组中的重复项 - 力扣(LeetCode)

题目:

给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。

考虑 nums 的唯一元素的数量为 k ,你需要做以下事情确保你的题解可以被通过:

  • 更改数组 nums ,使 nums 的前 k 个元素包含唯一元素,并按照它们最初在 nums 中出现的顺序排列。nums 的其余元素与 nums 的大小不重要。
  • 返回 k 。

解题思路:

1. 原地删除  双引用思想:指针 fir、sec

2. 步骤解析:

(1)fir==sec,指向数组首元素

(2) sec向后移动,如果碰见与fir指向元素不相同的位置,此时fir进行移动。

这一步骤可以理解为:数组中的[0,fir]区间内存放的是不重复的元素,而sec就是负责去找不重复的元素的。一旦找到,fir就得在区间内为这个元素开辟空间,即fir++;

无论是否碰见重复元素,sec引用指针是一直往后移动的;

fir指向的元素就是删除后有效的最后一个元素,最后的有效元素个数就是fir指向的索引+1。

代码实现:

public int RemoveArrayElements(int[] nums){int fir=0,sec=0;//sec移动到元素的末尾,此时fir就指向最后一个不重复的元素//nums[0,fir]区间均为不重复元素while(sec<nums.length){if(nums[fir]!=nums[sec]){fir+=1;nums[fir]=nums[sec];}sec++;}return fir+1;}

思考:如果删除所有重复元素,如何进行改进?


http://www.ppmy.cn/news/1124541.html

相关文章

蓄水池抽样算法

题目&#xff1a;在一个源源不断的数据流中&#xff0c;会吐出带有编号的球&#xff0c;现在问你 在不知道具体有多少个球的情况下&#xff0c;如何等概率的抽出10个球&#xff1f; 例题&#xff1a;leetcode 382题 应用场景&#xff1a;比如在某个游戏的抽奖活动中&#xff…

【深度学习实验】卷积神经网络(二):实现简单的二维卷积神经网络

目录 一、实验介绍 二、实验环境 1. 配置虚拟环境 2. 库版本介绍 三、实验内容 0. 导入必要的工具包 1. 二维互相关运算&#xff08;corr2d&#xff09; 2. 二维卷积层类&#xff08;Conv2D&#xff09; a. __init__&#xff08;初始化&#xff09; b. forward(前向传…

理德外汇:俄货币供应创新高,需平衡刺激与通胀

今年俄罗斯广义货币供应量M2继续快速增长&#xff0c;7月份同比增长24.7%&#xff0c;年初以来增长超过11%。这种增长很好地刺激了GDP&#xff0c;是今年GDP表现良好的主要原因之一&#xff0c;但其也加速了物价上涨&#xff0c;今年年初至今&#xff0c;俄通货膨胀率同比超过5…

LLM-TAP随笔——语言模型训练数据【深度学习】【PyTorch】【LLM】

文章目录 3、语言模型训练数据3.1、词元切分3.2、词元分析算法 3、语言模型训练数据 数据质量对模型影响非常大。 典型数据处理&#xff1a;质量过滤、冗余去除、隐私消除、词元切分等。 训练数据的构建时间、噪音或有害信息情况、数据重复率等因素都对模型性能有较大影响。训…

苹果Vision Pro头显内置AI芯片

苹果首席执行官蒂姆库克近日在接受采访时确认&#xff0c;备受瞩目的Vision Pro头显将按计划于明年初在美国上市。这款头显被认为是苹果自iPhone以来最重要的产品之一&#xff0c;售价高达3499美元。 蒂姆库克在接受CBS Sunday Morning的采访时透露&#xff0c;他的团队对Visi…

vue安装依赖报错install i 报错提示npm audit fix --force,or `npm audit` for details

vue项目执行npm install初始化后报错 run npm audit fix to fix them, or npm audit for details 出现这类提醒&#xff0c;按照如下操作进行 1、首先安装模块依赖&#xff1a; npm install &#xff08;npm audit fix 含义&#xff1a; 检测项目依赖中的漏洞并自动安装需要…

太阳能供电模块

基于Solar Cell的锂电池充放电模块 由于一些需求&#xff0c;最近做了一款基于太阳能的锂电池充放电模块。该模块能够利用太阳能为锂电池充电和为负载提供5V的电压&#xff0c;在太阳能不充足的条件下&#xff0c;由锂电池提供需要的能量。 主要思路是将太阳能板获得的能量存储…

Ubuntu 安装PostgreSQL

网上有各种版本的&#xff0c;也可以去官网看官方的文档。我是下载的PostgreSQL-11.4版本的。找到以后直接复制网上的压缩包链接就可以。 $ mkdir /opt/postgresql && cd /opt/postgresql $ wget https://ftp.postgresql.org/pub/source/v11.4/postgresql-11.4.tar.gz…