【LeetCode】80.删除有序数组中的重复项II

题目链接:

80.删除有序数组中的重复项II

题目描述:

解题思路:

按照题目中要求,必须在原来数组中进行修改,并且在O(1)额外空间条件下完成。因此我们可以使用双指针算法,算法具体流程如下:

  • 如果数组长度 nums.size() <= 2, 则直接 return nums.size()即可
  • 定义两个指针 slowfast,并初始化为2
  • 如果 nums[slow - 2] == nums[fast],说明已经有两个数相等,因此 nums[fast] 数值不能放进结果之中。反之,如果nums[slow - 2] != nums[fast],那么nums[fast]可以放进nums[slow]中,并且slow++,记录结果的长度
  • fast>=nums.size()的时候,结束循环,返回数组长度slow

复杂度分析:

  • 时间复杂度O(n)
  • 空间复杂度O(1)

代码实现:

cpp 复制代码
class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        int n = nums.size();
        if(n<=2){
            return n;
        }
        int slow = 2;
        int fast = 2;

        while(fast<n){
            if(nums[slow-2] != nums[fast]){
                nums[slow] = nums[fast];
                slow++;
            }
            fast++;
        }
        return slow;
    }
};

进一步可以优化掉快指针fast:

cpp 复制代码
class Solution {
public:
    int removeDuplicates(vector<int>& nums) {

        int slow = 0;
        for(int num : nums){
            if(slow<2 ||  nums[slow-2] < num){
                nums[slow] = num;
                slow++;
            }
        }

        return slow;
    }
};

解题思路参考:
https://leetcode.cn/problems/remove-duplicates-from-sorted-array-ii/solutions/702869/ju-yi-fan-er-ni-zhen-de-zhen-de-zhi-de-x-eicz/?envType=study-plan-v2&envId=top-interview-150

相关推荐
Struart_R2 分钟前
Easi3R、VGGT4D、4D-VGGT论文解读
人工智能·计算机视觉·三维重建·4d·vggt
wincheshe5 分钟前
AI Agent 开发 --- 上下文工程:概念与落地实践(四)
人工智能
墨染天姬12 分钟前
【AI】强化学习(RL)和多智能体系统(MAS)
人工智能
柯儿的天空20 分钟前
【OpenClaw 全面解析:从零到精通】第 013 篇:OpenClaw 安全机制深度解析——沙盒隔离、权限控制与安全最佳实践
人工智能·安全·ai作画·aigc·ai写作
知智前沿22 分钟前
什么是 RAG?通俗易懂讲解 + 核心流程梳理
人工智能·python
IT猿手31 分钟前
基于强化学习Q-learning算法的无人机三维路径规划算法原理与实现,MATLAB代码
算法·matlab·无人机·路径规划·动态路径规划
qq_4176950532 分钟前
C++中的解释器模式
开发语言·c++·算法
星爷AG I33 分钟前
15-5 身体感觉:疼觉和温觉(AGI基础理论)
人工智能·agi
y = xⁿ37 分钟前
【LeetCodehot100】T108:将有序数组转换为二叉搜索树 T98:验证搜索二叉树
数据结构·算法·leetcode
云和数据.ChenGuang39 分钟前
鸿蒙餐饮系统:全场景智慧餐饮新范式
人工智能·机器学习·华为·数据挖掘·harmonyos·鸿蒙·鸿蒙系统