LeetCode刷题笔记第80题:删除有序数组中的重复项 II

LeetCode刷题笔记第80题:删除有序数组中的重复项 II

题目:

删除升序数组中超过两次的元素后的数组长度

想法:

使用快慢指针的方法完成,使用快指针遍历整个数组,使用慢指针完成相同元素最多保留两个。在快指针遍历到超过两个相同元素时,慢指针停止移动,等到快指针遍历的不同的元素时,将不同元素赋值给慢指针所在位置并向后移动一位,直至快指针遍历完整个数组,慢指针所在的位置即为删除后的数组长度。

python 复制代码
class Solution:
    def removeDuplicates(self, nums: List[int]) -> int:
        slow = 0
        for fast in range(len(nums)):
            if slow < 2 or nums[fast] != nums[slow - 2]:
                nums[slow] = nums[fast]
                slow += 1
        return slow

时间复杂度:O(N)

空间复杂度:O(1)

本题中的想法主要是利用快指针遍历数组找到所有不超过两个的相同元素,并将这些元素赋值给慢指针所指,因为是在原数组上的原地操作,所以慢指针所指新数组没有产生额外的空间占用

相关推荐
徐安安ye20 小时前
FlashAttention的OOM排查:为什么显存够了还是报内存不足?
人工智能·算法·机器学习
2601_9578822420 小时前
一条视频如何自动适配5大平台的技术实现
人工智能·算法·机器学习
kgduu20 小时前
ethers.js学习笔记
javascript·笔记·学习
子琦啊20 小时前
【算法复习】哈希|Map 与 Set 两个高频套路
算法·哈希算法
Alaso_shuang20 小时前
视觉组通识
数码相机·算法·计算机视觉
纽扣66720 小时前
【算法进阶之路】链表终极进阶:合并 K 个有序链表 + 复制带随机指针的链表(含双解法)
数据结构·算法·链表
会编程的土豆21 小时前
Docker 日常操作笔记(开发最常用命令)
笔记·docker·容器
05候补工程师21 小时前
【考研英语一·翻译专攻】长难句翻译的“分治策略”:从底层拆分到逻辑重构(1997-2010真题高频陷阱与红笔纠偏)
经验分享·笔记·考研·重构
有味道的男人21 小时前
Open Claw对接小红书笔记详情
数据库·笔记
迈巴赫车主21 小时前
码蹄集 MC0457符咒封印java
java·数据结构·算法