【practise】删除有序数组中的重复项

news2025/1/12 23:12:57

关于博主:

在这里插入图片描述

今天分享一道简单的关于“双指针”算法的题目。算是双指针中非常基础的题目,有兴趣可以借鉴一波~

目录

    • 1.题目介绍
    • 2.题解思路:`双指针法`
    • 3.代码示例

1.题目介绍

题目链接:LINK
在这里插入图片描述

本题要求是:对给定的有序数组nums删除重复元素,使得每种元素仅在该数组中出现一次,并返回新的数组长度。请注意,上述操作必须在原数组中进行(即使用O(1)空间复杂度去解决此问题)。

2.题解思路:双指针法

给定数组是有序的,任何相同的元素均相邻。 题目中介绍,这是一个非严格递增的数组,变相告诉我们该数组是有序的,因此我们可以推的该数组中所有重复元素按均相邻。
在这里插入图片描述

特殊情况,数组元素个数为0时返回0。 nums为0,则证明没有任何元素,可以直接返回0(这点题目中没有明确说明)。

一般情况,数组元素个数大于0。 一般情况下,数组中至少有一个元素,因此在删除重复元素之后也会至少剩下一个元素,因此我们可知nums[0]保持原样即可,不必修改,因为nums[0]是删除后一定存在的。因此我们从下标1处开始检查并删除元素。
在这里插入图片描述

快慢指针法:指定两个指针,一个fast指针(快指针)用于在数组前面遍历检查,另一个slow指针(满指针)用于把表示下一个不同元素填入指定下标位置。初始情况下,fast指向1(0处不用进行检查,因为必定不会被删除),slow指向0。
假设数组的总长度为n,按照快慢指针法快指针将依次遍历下标1-n-1处的数字,当检查到与slow位置的值不相同时,则++slow,把该不同的数据填入到slow位置下;如果fast指针遍历到的数字与slow相同,那么我们继续fast++;
在这里插入图片描述

返回值:遍历结束后,我们slow指向的位置及前面所有位置均是有效数字,我们返回slow + 1即可。
在这里插入图片描述

3.代码示例

class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        // 双指针法解答
        int slow = 0, fast = 1;//快慢指针

        while(fast < nums.size())
        {
            if(nums[fast] != nums[slow])//如果快指针对应的值不等于慢指针
            {
                nums[++slow] = nums[fast];//满指针先++,再把不同的值拷贝给nums[slow]
            }
           
           fast++;//继续遍历下一个
        }

        return slow + 1;//返回慢指针+1
    }
};

不知你是否还有更好的思路,欢迎评论分享~

在这里插入图片描述


EOF

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1986049.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Android中的沉浸式丝滑转场之共享元素转场动画

文章目录 1. 介绍2. 实现方法3. 举例演示3.1 举例一&#xff1a;普通页面间共享元素转场动画3.2 举例二&#xff1a;列表页面共享元素转场动画 4. 总结 1. 介绍 在Android开发中&#xff0c;经常会有页面转场的动画效果。普通的转场动画不过是左进右出&#xff0c;渐显渐隐&am…

树莓派4B学习笔记24:Python_SYN6288语音模块的控制函数

今日继续学习树莓派4B 4G&#xff1a;&#xff08;Raspberry Pi&#xff0c;简称RPi或RasPi&#xff09; 本人所用树莓派4B 装载的系统与版本如下: 版本可用命令 (lsb_release -a) 查询: ​ Opencv 版本是4.5.1&#xff1a; ​ Python 版本3.7.3&#xff1a; 今日学习SYN6288语…

叛逆,批判

1、对以往说法的批判之一&#xff08;第一次这么公开批判是2004-2005年&#xff09;&#xff1a; 这部英文版的《数学百科全书》似乎是从俄语版翻译过来的&#xff1f;我查了三本引用的图书文献&#xff0c;都没有关于“nonsingular”和“singular”的类似下面的说法&#xff…

加密市场再遭重创:多重利空因素引发超10亿美元抛售潮

四年前的全球“熔断潮”仿佛还在眼前&#xff0c;如今金融市场再度迎来剧烈震荡&#xff0c;全球股市与加密货币市场遭遇多重利空冲击&#xff0c;尤其是比特币和以太坊的闪崩使得市场恐慌情绪蔓延。这个“黑色星期一”不仅见证了股市的跳水&#xff0c;还标志着加密市场的又一…

每日学习笔记:C++ STL算法之已排序区间算法

目录 查找元素 检查某个元素是否存在: binary_search(beg, end, value) binary_search(beg, end, value, op) 检查数个元素是否存在&#xff1a; includes(beg, end, searchBeg, searchEnd) includes(beg, end, searchBeg, searchEnd, op) ​编辑 查找第一个或最后一…

网安新声 | 微软蓝屏事件安全启示录

网安加社区【网安新声】栏目&#xff0c;汇聚网络安全领域的权威专家与资深学者&#xff0c;紧跟当下热点安全事件、剖析前沿技术动态及政策导向&#xff0c;以专业视野和前瞻洞察&#xff0c;引领行业共同探讨并应对新挑战的策略与可行路径。 2024年7月19日&#xff0c;微软发…

搭建Mysql主从架构

一、主从 1、备份的三种类型 热备份逻辑备份物理备份 二、集群 1、概述 高可用集群&#xff08;HA&#xff09;是指通过特殊软件&#xff0c;把独立的服务器连接起来&#xff0c;组成一个能够提供故障间切换功能的集群。 2、标准 可用性级别 年宕机时间 描述 99% 3.65天 …

蜂窝网络架构

2G/3G 4G eNB RF-RRU eCPRI RRU-BBU 光纤 5G From 38.300 AMF处理信令等&#xff0c;UPF 用户面&#xff0c;后面还有SMF

Day20 文件IO

feof&#xff08;FILE*&#xff09; 用于检测文件是否到达结尾 ferror&#xff08;FILE*&#xff09; 检测文件是否发生错误 clearerr&#xff08;FILE*&#xff09; 清除错误 一.文件IO的特性 1 没有缓存区 2 操作对象不在是流&#xff0c;而是文件描述符 3…

埃拉托斯特尼筛法,厄拉多塞筛算法,C#实现

埃拉托斯特尼筛法&#xff0c;厄拉多塞筛算法 这个 很多地方的定义不一样。 虽然名字相同&#xff0c;但是具体的定义还是有差距。 有的地方描述的是&#xff1a; 厄拉多塞筛算法(Eratosthenes Sieve)是一种求素数的方法&#xff0c;由古希腊数学家厄拉多塞提出。它的原理是&…

如何下载学术论文、专利(最全)——包含免费方法

经常有同学问&#xff0c;如何下载论文 一、中文论文 万方&#xff08;在校生一般学校已购买权限&#xff0c;具体可看自己学校图书馆&#xff09; 网址&#xff1a;https://www.wanfangdata.com.cn/ 2. 知网&#xff08;在校生一般学校已购买权限&#xff0c;具体可看自己学…

【ML】transform 之 encode 及其实现细节

transform 之 encode 及其实现细节 1. transform (seq2seq) 是什么2. transform (seq2seq) 具体如何实现3. transform (seq2seq) 可以解决哪些类型的问题4. 补充问题4.1 残差连接&#xff08;Residual Connection&#xff09;是什么如何实现4.1.2 残差连接的具体实现&#xff1…

一文搞懂后端面试之MySQL MVCC【中间件 | 数据库 | MySQL | 隔离级别 | Read View】

为什么需要MVCC 锁本身就是用于并发控制的&#xff0c;那么为什么InnoDB还要引入MVCC&#xff0c;读写都加锁不就可以控制住并发吗&#xff1f; 锁确实可以&#xff0c;但是性能太差。如果是纯粹的锁&#xff0c;那么写和写、读和写、读和读之间都是互斥的。如果是读写锁&…

C#TreeView控件应用

1、代码 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.IO; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms;namespace TestApp…

两数之和 II(LeetCode)

题目 给你一个下标从 1 开始的整数数组 &#xff0c;该数组已按 非递减顺序排列 &#xff0c;请你从数组中找出满足相加之和等于目标数 的两个数。 如果设这两个数分别是 和 &#xff0c;则 。 以长度为 的整数数组 形式返回这两个整数的下标 和 。 你可以假设每个输入…

【从零开始一步步学习VSOA开发】并行RPC服务端

并行RPC服务端 概念 之前 RPC 使用方式中的所有回调函数都是串行执行的&#xff0c;VSOA 为 C 语言开发版本提供了并行处理 RPC 请求的功能&#xff0c;开发者可以通过并发 RPC 相关接口创建线程池并行处理 RPC 请求。并发服务模式通过多线程来实现&#xff0c;能有效提高响应…

8.06 C++作业

使用类定义实现隔离储存计算 1.头文件 #ifndef CLASS_H #define CLASS_H #include <iostream> using namespace std;class rect { private:int width;int height; public:void init(int width,int height);void show();void setw(int w);void seth(int h); };#endif //…

gradle安装及配置

文章目录 一、下载安装包二、解压文件三、环境变量配置四、验证安装结果五、配置国内源六、IDEA配置 一、下载安装包 从gradle官网下载安装包&#xff0c;官网地址为&#xff1a;https://gradle.org/releases/ 我们只需要下载编译好的文件即可。 二、解压文件 解压文件到指定…

睡前故事—星际旅行者

文章目录 欢迎来到《Bedtime Stories Time》。这是一个我们倾听、放松、并逐渐入睡的播客。感谢你收听并支持我们&#xff0c;希望你能将这个播客作为你睡前例行活动的一部分。今晚我们将讲述《星际旅行者》的故事。一个宁静的夜晚&#xff0c;希望你现在已经感到平静、放松&am…

PXE的使用

配置前提 1、挂载镜像源&#xff0c;可正常下载软件 [rootredhat-7 ~]# mkdir -p /rhel7 ----创建挂载点目录 [rootredhat-7 ~]# mount /dev/sr0 /rhel7/ ----挂载镜像源至挂载点&#xff08;临时挂载&#xff0c;重启失效&#xff09;[rootredhat-7 ~]# vim /etc/yum.repos.…