LeetCode热题100-26. 删除有序数组中的重复项

给你一个 非严格递增排列 的数组 nums ,请你**原地** 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。

考虑 nums 的唯一元素的数量为 k。去重后,返回唯一元素的数量 k

nums 的前 k 个元素应包含 排序后 的唯一数字。下标 k - 1 之后的剩余元素可以忽略。

题目要求原地删除重复元素,所以不能直接使用del删除元素,这样会导致顺序错乱,也不是原地,原地只能交换,所以使用快慢指针。当遇到快慢指针值不相同时进行先+1再交换,如果相同值直接跳过。时间复杂度O(n),空间复杂度O(1)

python 复制代码
class Solution:
    def removeDuplicates(self, nums: List[int]) -> int:
        if not nums:
            return 0
        slow = 0
        for fast in range(1, len(nums)):
            if nums[slow] != nums[fast]:
                slow += 1
                nums[slow] = nums[fast]
        return slow + 1
相关推荐
Warson_L28 分钟前
Python `Annotated` 与 LangGraph Reducer 学习笔记
python
韩师傅29 分钟前
海天线算法的前世今生
python·计算机视觉
韩师傅33 分钟前
当你的甲方设备过烂,要如何快速出效果?
python·计算机视觉
Warson_L36 分钟前
LangGraph的MessageState and HumanMessage
python
韩师傅1 小时前
当你的甲方吐槽天空不够蓝,你应该如何应对
python·计算机视觉
Warson_L2 小时前
python的类&继承
python
Warson_L2 小时前
类型标注/type annotation
python
ThreeS4 小时前
手搓MiniVLA全实战教程-一步一步用pytorch解释原理与思路
人工智能·python
金銀銅鐵6 小时前
[Python] 模 n 乘法的逆元计算器
python·数学·游戏