算法题(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)

相关推荐
前端小白在前进1 小时前
力扣刷题:在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
LBJ辉4 小时前
第 4 章 串
数据结构·考研
似水এ᭄往昔5 小时前
【C++】--封装红⿊树实现mymap和myset
开发语言·数据结构·c++·算法·stl
山楂树の6 小时前
搜索插入位置(二分查找)
数据结构·算法
Ka1Yan6 小时前
[二叉树] - 代码随想录:二叉树的统一迭代遍历
数据结构·算法·leetcode
Sheep Shaun7 小时前
二叉搜索树(下篇):删除、优化与应用
数据结构·c++·b树·算法
鱼鱼块7 小时前
二叉搜索树:让数据在有序中生长的智慧之树
javascript·数据结构·面试
jianfeng_zhu8 小时前
二叉树的中序线索化,并通过线索化后遍历二叉树
数据结构·链表
C雨后彩虹8 小时前
5G网络建设
java·数据结构·算法·华为·面试
酸菜牛肉汤面8 小时前
5、索引的数据结构(b+树,hash)
数据结构·b树·哈希算法