LeetCode面试题Day1|LeetCode26 删除有序数组中的重复项、LeetCode80 删除有序数组中的重复项Ⅱ

前言:

暑假实在不知道干什么了,做一下力扣的《面试经典150题》吧,记录一下学习轨迹。(如果有要打非中文竞赛或者精进一下英语水平的记得把力扣调成英文)

题目1:

指路:

. - 力扣(LeetCode)26 删除有序数组中的重复项

思路与分析:

在这里我们不难看出本题有两个点,第一个是原地修改 (英文版为"in-place")显然不能再开拓空间,第二个是删除重复元素最后得到一个无重复元素 数组的大小。注意:要求元素相对顺序保持一致,那么不可以排序避免导致顺序更改。题目中还给了一个k,其含义为最后符合条件的数组大小为k。我们可以从数组的大小开始入手讨论,当数组的大小为1时肯定没有重复,这时候直接输出即可。那么当数组的大小大于1时,就有元素重复的可能。我们可以从第二个元素开始与前一个元素进行比较,当两个元素不相等时收纳第二个元素,否则不做处理。那么如何保留符合条件的元素?拿到k,初始化k为1代表直接收纳原数组中第一个元素,之后遍历数组进行元素比较一直到数组遍历完成,其中满足条件的元素收纳,最后返回k即可。

代码:

1.正常做法:

cpp 复制代码
class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
    int k = 1;  // 符合条件的值放的地方
    for (int i = 1; i < nums.size(); i++) {
        if (nums[i] != nums[i - 1]) {
            nums[k++] = nums[i];
        }
    }    
    return k;
    }
};

2.库函数(投机取巧法):

在这里用到了erase和unique两个函数,在这里这一行的意义为遍历nums数组,将不唯一的元素放在数组的最后部分,再用erase函数删掉最后这部分。

cpp 复制代码
class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
    nums.erase(unique(nums.begin(), nums.end()), nums.end());
    return nums.size();    
    }
};

题目2:

指路:

. - 力扣(LeetCode)80 删除有序数组中的重复项Ⅱ

思路与分析:

依旧是在原内存上删除重复元素,那么不同于上题的是允许有两个元素相等 ,如果有三个或者多个相等的元素那么删掉第三个及后面所有的相等的元素。换言之,例如一个数组中只有三个元素[1, 2, 2],我们无需判断第一个元素和第二个元素 的关系,只需要判断第一个和第三个 元素的关系即可。因此从第三个元素开始与它前面的前面的元素进行比较(假设该元素的位置是i,则判断nums[i]与nums[i-2]即可)。那么在这里我们定义两个指针 分别指向第一个元素和第三个元素,当两者相等时证明第三个元素不符合规定,不收纳且将指向第三个元素的指针向后移一位 ,反之二者不相等则说明第三个元素符合条件此时收纳第三个元素并使指向第一个元素的指针后移一位。最后返回即可。

代码:

cpp 复制代码
class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
    int n = nums.size();
    if (n <= 2) return n;
    int fast = 2; int slow = 2;
    while (fast < n) {
        if (nums[slow - 2] != nums[fast]) {
            nums[slow] = nums[fast];
            slow++;
        }
        fast++;
    }
    return slow;
    }
};
相关推荐
咸鱼爱学习6 分钟前
【题解】B2613【深基1.习5】打字速度
数据结构·c++·算法
一匹电信狗9 分钟前
【C++】C++风格的类型转换
服务器·开发语言·c++·leetcode·小程序·stl·visual studio
学学学无无止境1 小时前
力扣-上升的温度
leetcode
云青黛1 小时前
轮廓系数(一个异型簇的分类标准)
人工智能·算法·机器学习
云青黛1 小时前
肘部法找k
人工智能·算法·机器学习·聚类
CHANG_THE_WORLD1 小时前
if条件语句 三目运算符 汇编分析
汇编·算法·条件语句·if 语句·汇编分析·条件语句汇编分析
tumu_C1 小时前
无用知识研究:在trailing return type利用decltype,comma operator在对函数进行sfinae原创 [二]
开发语言·c++·算法
web安全工具库1 小时前
告别刀耕火种:用 Makefile 自动化 C 语言项目编译
linux·运维·c语言·开发语言·数据库·算法·自动化
海蓝可知天湛2 小时前
利用Genspark自定义智能体:算法竞赛测试数据反推与生成工具
算法·aigc
BothSavage2 小时前
Qwen3-VL-8B-Instruct推理测试transformer+sglang双版本
算法