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
相关推荐
武帝为此2 小时前
【热卡填充法介绍】
人工智能·python·机器学习
片酷2 小时前
【Isaacsim&Isaaclab】安装教程
linux·开发语言·python
RunsenLIu2 小时前
019 | backtrader回测布林带突破策略
开发语言·python
睡觉就不困鸭2 小时前
第14天 四数之和
数据结构·算法
云泽8082 小时前
二叉树高阶笔试算法题精讲(一):序列化、层序遍历、LCA 与 BST 转换
数据结构·c++·算法
weixin_381288182 小时前
Layui怎么在表格标题栏中嵌入一个迷你的HTML搜索表单
jvm·数据库·python
再卷也是菜2 小时前
算法提高篇(3)线段树(下)
算法
m0_747854522 小时前
C# 文件系统Filter Hook C#能否在用户模式下拦截文件系统调用
jvm·数据库·python
嘻嘻哈哈樱桃2 小时前
牛客经典101题题解集--二叉树
java·数据结构·python·算法·leetcode·职场和发展