算法题(18):删除有序数组中的重复项2

审题:

需要原地删除数据让数组中一个数据只能出现最多2次,并返回修改后的数组的数据个数

(不会有空数组情况)

思路:

双指针:我们用left指向下一个需要插入数据的位置,right去遍历数组

left数据的个数小于2时,我们就可以插入数据到left中,若数据与前一个相同则cou++,不同则让cur等于一。

left数据的个数大于等于二则直接访问下一个数据,直到遇到不同的数据

解题:

(1)left为什么从1开始,cou为什么从1开始?

其一,第一个数据是可以直接插入的,所以直接从索引为1的位置开始插入数据,而因我们已经有一个数据默认插入了,所以cur就是初始化为1

其二,若不让left初始化为1,那么在left为0时无法访问left-1位置,会越界

(2)left表示的是待插入数据的位置,所以判断新数据需要和left-1的位置数据去判断

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

相关推荐
穿过锁扣的风3 分钟前
决策树:从入门到实战,解锁 AI 分类预测的核心利器
数据结构·python·决策树
数智工坊4 分钟前
【数据结构-线性表】2.2单链表
数据结构
牛马大师兄6 分钟前
数据结构复习 | 单向链表
c语言·数据结构·笔记·链表
青桔柠薯片12 分钟前
数据结构:单向链表和双向链表
数据结构·算法·链表
2401_8414956415 分钟前
【LeetCode刷题】对称二叉树
数据结构·python·算法·leetcode·二叉树··递归
Hello World . .1 小时前
排序算法:常用排序算法
c语言·数据结构·算法·vim·排序算法
虢薪1 小时前
双向链表与循环链表基础操作&进阶操作
数据结构·链表
寄存器漫游者1 小时前
数据结构 单向链表进阶
数据结构·链表
秋深枫叶红1 小时前
嵌入式C语言阶段复习——函数
c语言·数据结构·算法
生命不息战斗不止(王子晗)1 小时前
2026面试大纲 - java数据结构与集合专题
java·数据结构·面试