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;
    }
};
相关推荐
java修仙传3 分钟前
力扣hot100:每日温度
算法·leetcode·职场和发展
咚咚王者6 分钟前
人工智能之核心基础 机器学习 第十章 降维算法
人工智能·算法·机器学习
源代码•宸14 分钟前
Golang语法进阶(Context)
开发语言·后端·算法·golang·context·withvalue·withcancel
源代码•宸16 分钟前
Golang语法进阶(Sync、Select)
开发语言·经验分享·后端·算法·golang·select·pool
sali-tec16 分钟前
C# 基于OpenCv的视觉工作流-章8-形态学
人工智能·深度学习·opencv·算法·计算机视觉
栈与堆20 分钟前
数据结构篇(1) - 5000字细嗦什么是数组!!!
java·开发语言·数据结构·python·算法·leetcode·柔性数组
LightYoungLee29 分钟前
算法(五)树 Trees V2
学习·算法·深度优先
enmouhuadou35 分钟前
什么是I/Q信号?
算法·信息与通信
2301_800256112 小时前
第九章:空间网络模型(空间网络查询、数据模型、Connected、with Recursive、pgRouting)
网络·数据库·算法·postgresql·oracle
逑之3 小时前
C语言笔记10:sizeof和strlen,指针与数组
c语言·笔记·算法