力扣删除有序数组中的重复项C++

题目


知识点


思路

此题使用双指针法,O(n)的时间复杂度,拼速度的话,可以剪剪枝。

注意题目中:不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。

双指针法,动画如下:


错误

返回的是删除重复元素后,数组的新长度


题解

cpp 复制代码
class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        if(nums.size() == 0){
            return 0;
        }
        int slow = 0;
        int fast = 1;
        while(fast < nums.size()){
            if(nums[slow] != nums[fast]){//不等就是出现不重复的元素
                nums[++slow] = nums[fast];//放到新位置
            }
            fast++;
        }
        return slow + 1;
    }
};
相关推荐
geneculture5 分钟前
本真信息观:基于序位守恒的融智学理论框架——人类认知第二次大飞跃的基础
人工智能·算法·机器学习·数据挖掘·融智学的重要应用·哲学与科学统一性·融智时代(杂志)
kronos.荒6 分钟前
动态规划——最长递增子序列系列问题(python)
算法·动态规划·最长递增子序列系列问题
生信研究猿23 分钟前
#P4625.第2题-大模型训练显存优化算法
算法
逻辑驱动的ken26 分钟前
Java高频面试考点14
开发语言·数据库·算法·哈希算法
故事还在继续吗30 分钟前
C++17关键特性
开发语言·c++·算法
Rabitebla33 分钟前
【数据结构】消失的数字+ 轮转数组:踩坑详解
c语言·数据结构·c++·算法·leetcode
菜菜的顾清寒35 分钟前
力扣100(20)旋转图像
算法·leetcode·职场和发展
Navigator_Z35 分钟前
LeetCode //C - 1025. Divisor Game
c语言·算法·leetcode
深念Y36 分钟前
王者荣耀与英雄联盟数值设计对比:穿透、乘算与加算、增伤乘算更厉害,减伤加算更厉害
数学·算法·游戏·建模·游戏策划·moba·数值
budingxiaomoli43 分钟前
优选算法-多源bfs解决拓扑排序问题
算法·宽度优先