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

相关推荐
louisdlee.3 分钟前
树状数组维护DP——前缀最大值
数据结构·c++·算法·dp
minji...1 小时前
算法题 逆波兰表达式/计算器
数据结构·c++·算法·1024程序员节
循着风5 小时前
二叉树的多种遍历方式
数据结构·算法
.格子衫.10 小时前
022数据结构之树状数组——算法备赛
数据结构·算法·1024程序员节
Yupureki10 小时前
从零开始的C++学习生活 16:C++11新特性全解析
c语言·数据结构·c++·学习·visual studio
對玛祷至昏12 小时前
数据结构理论知识
数据结构·算法·排序算法
黄思搏12 小时前
红黑树 - Red-Black Tree 原理与 C# 实现
数据结构·1024程序员节
剑锋所指,所向披靡!12 小时前
数据结构的基本概念
数据结构
dragoooon3413 小时前
[优选算法专题四.前缀和——NO.31~32 连续数组、矩阵区域和]
数据结构·算法·leetcode·1024程序员节
py有趣13 小时前
LeetCode算法学习之移除元素
java·数据结构·算法