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

删除有序数组中的重复项

目录

题目: 

示例:

题目分析:

解题思路:


题目: 

  • 给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。
  • 考虑 nums 的唯一元素的数量为 k ,你需要做以下事情确保你的题解可以被通过:
  • 更改数组 nums ,使 nums 的前 k 个元素包含唯一元素,并按照它们最初在 nums 中出现的顺序排列。nums 的其余元素与 nums 的大小不重要。
  • 返回 k 

26. 删除有序数组中的重复项 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/remove-duplicates-from-sorted-array/description/ 

示例:

 

题目分析:

从题目得知,我们要在一个递增的数组中,删去数组内部的重复出现的元素,并且要直接在数组上进行删除操作,且最后需要数组保持递增的顺序。

解题思路:

  • 因为我们要在数组内部进行删除操作,于是我们可以采取覆盖操作,将重复的元素覆盖,对此我们可以使用指针进行覆盖操作。
  • 但是,当覆盖后,又会多出重复的元素,因此还需要一个指针用来覆盖 覆盖的元素。
  • 又因为根据示例,我们最后返回的是删去重复项后,数组的长度。
  • 所以最后可以转变为,使用两个指针,其中一个为快指针  fast ,另一个是慢指针 slow ,fast指向数组的第二个元素,slow指向数组的第一个元素。
  • 随后,将两个指针指向的元素进行比较,如果二者指向的元素不同,则二者同时向前走一步。
  • 若二者元素相同,则slow朝前走,fast保持不动,并且将fast的赋予slow指向的值。

图例来源:Necho - 力扣(LeetCode) 

 

代码演示:

int removeDuplicates(int* nums, int numsSize){int fast  =1;int slow =0;while(fast<numsSize){if(nums[slow]==nums[fast]){fast=fast+1;}else{slow= slow+1;nums[slow]=nums[fast];}}return slow +1;}

 


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

相关文章:

  • 【数据库】
  • 高级深入--day38
  • 基于springboot,vue校园社团管理系统
  • 广州华锐互动:VR虚拟现实物理学习平台,开启数字化教学新格局
  • 【tio-websocket】8、T-IO对半包和粘包的处理
  • 【Linux】安装与配置虚拟机及虚拟机服务器坏境配置与连接
  • Redis常识
  • Instant,LocalDate,LocalTime,LocalDateTime和ZonedDateTime
  • Web入门笔记
  • Linux网络编程二(TCP三次握手、四次挥手、TCP滑动窗口、MSS、TCP状态转换、多进程/多线程服务器实现)
  • C#核心笔记——(一)C#和.NET Framework
  • 【2023年冬季】华为OD统一考试(B卷)题库清单(已收录345题),又快又全的 B 卷题库大整理
  • 云服务器的先驱,亚马逊云科技海外云服务器领军者
  • QT webengine显示HTML简单示例
  • Spark_SQL函数定义(定义UDF函数、使用窗口函数)
  • 【Leetcode】【每日一题】【中等】274. H 指数
  • MySQL读写分离技术及实现方案
  • git 推送到github远程仓库细节处理(全网最良心)
  • 算法训练|数据流中的中位数
  • LeetCode 2558. 从数量最多的堆取走礼物【模拟,堆或原地堆化】简单
  • windows服务器环境下使用php调用com组件
  • 3DCAT+东风日产:共建线上个性化订车实时云渲染方案
  • 【VR开发】【Unity】【VRTK】1-无代码VRVR开发介绍
  • 全国地级市最新城投债数据(2006-2023.2)
  • vm_flutter
  • MySQL数据库#6
  • YOLO v1(2016.5)
  • SQL比较两次的字段集合,找出并返回差异,主要用于更新记录事件
  • muduo源码剖析之Acceptor监听类
  • express session JWT JSON Web Token