当前位置: 首页 > news >正文

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

前言:

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

题目1:

指路:

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

思路与分析:

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

代码:

1.正常做法:

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函数删掉最后这部分。

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]即可)。那么在这里我们定义两个指针分别指向第一个元素和第三个元素,当两者相等时证明第三个元素不符合规定,不收纳且将指向第三个元素的指针向后移一位,反之二者不相等则说明第三个元素符合条件此时收纳第三个元素并使指向第一个元素的指针后移一位。最后返回即可。

代码:

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;}
};

http://www.lryc.cn/news/417529.html

相关文章:

  • 细说文件操作
  • Vue3从零开始——掌握setup、ref和reactive函数的奥秘
  • C语言练习--屏幕上打印九九乘法表
  • 将tsx引入vue
  • 前端实现签字效果+合同展示
  • [AI Embedchain] 开始使用 - 快速开始
  • Linux网络协议.之 tcp,udp,socket网络编程(三).之多进程实现并发demon
  • Java线程(练习题)
  • MySQL:初识数据库初识SQL建库
  • 关于Redis的集群面试题
  • 带头双向循环链表(一)
  • 深入理解Win32K.sys的工作原理
  • 力扣面试经典算法150题:删除有序数组中的重复项
  • 文本加密工具类-支持MD5、SHA1、SHA256、SHA224、SHA512、SHA384、SHA3、RIPMD160算法
  • LVS集群中的负载均衡技术
  • Java网络编程——HTTP协议原理
  • java之多线程篇
  • 【深度学习】TTS,CosyVoice,训练脚本解析
  • 《Unity3D网络游戏实战》学习与实践
  • Machine_Matrix打靶渗透【附代码】(权限提升)
  • 代码随想录算法训练营Day22 | Leetcode 77 组合 Leetcode 216 组合总和Ⅲ Leetcode17 电话号码的字母组合
  • 【微信小程序实战教程】之微信小程序中的 JavaScript
  • K-近邻算法(一)
  • 从零开始之AI视频制作篇
  • Java之TCP编程综合案例
  • 【数据分析---Pandas实战指南:精通数据查询、增删改操作与高效索引和列名操作管理】
  • Spring Cloud全解析:注册中心之Eureka服务获取和服务续约
  • 三相整流电路交流侧谐波仿真分析及计算
  • 了解Java中的反射,带你如何使用反射
  • 【c++】基础知识——快速入门c++