剑指 Offer 03.:数组中重复的数字

news2025/1/19 17:05:22

剑指 Offer 03. 数组中重复的数字

找出数组中重复的数字。 在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。

示例 1:

输入:
[2, 3, 1, 0, 2, 5, 3]
输出:2 或 3 

限制:

2 <= n <= 100000


思路分析:排序+查找

题目显而易见的一个解决方法是对该数组进行排序,然后在排序的数组中查找出重复元素就很容易了,至于排序的方法,为了熟悉一下快排,因此在这里我使用的是手写的快排。具体见下面的解法一。

C++代码:
class Solution {
public:
    int findRepeatNumber(vector<int>& nums) {
		int n = nums.size();
		//1.排序
		//也可以用库函数
		//sort(nums.begin(),nums.end());
		quickSort(nums,0,n-1);
		//2.查找
		for(int i=0;i<n;i++)
		{
			if(nums[i]==nums[i+1])
				{
					return nums[i];
				}
		}
		return -1;
    }
	
	//快排
	void quickSort(vector<int>&a,int left,int right)
	{
		//特判
		if(left>=right) return;
		int i = left-1;
		int j = right+1;
		int x = a[left+right>>1];
		while(i<j)
		{
			do i++;while(a[i]<x);
			do j--;while(a[j]>x);
			if(i<j)
			{
				swap(a[i],a[j]);
			}
		}
		//递归左边部分
		quickSort(a,left,j);
		//递归右边部分
		quickSort(a,j+1,right);
	}
};
复杂度:

时间:排序一个长度为n的数组需要 O(nlogn) 的时间。

空间:常数空间 O(1)


思路分析:(优化)哈希表

提到 重复二字,必然少不了哈希表。具体的,遍历整个数组,每次扫描数组中每一个值,可以判断其有没有在哈希表中,如果在,直接返回,否则,只需要更新一下哈希表状态即可。

C++代码:
class Solution {
public:
    int findRepeatNumber(vector<int>& nums) {
        int n = nums.size();
		//开一个哈希表
        unordered_map<int,bool> mp;
		//遍历nums数组
        for(int i:nums)
        {
			//如果该值已存在,直接返回
            if(mp[i])
            {
                return i;
            }
			//更新一下哈希表的状态
            mp[i] = true;
        }
        return -1;
    }
};
复杂度:

时间:由于哈希表每次判断只需要O(1)的时间,长度为n的数组,因此复杂度为O(n)。

空间:毫无疑问,这种解法使得在时间上得到了优化,同时却是以牺牲O(n)的哈希表空间换取的,所以空间复杂度为O(n)


思路分析:(再优化)原地交换

原地交换??

在具体的题目中,有的解题方法是需要我们对题目已经其数据进行观察,找到规律进而得到一条捷径,这里不妨以提供的用例:[2, 3, 1, 0, 2, 5, 3]配合图解来加以论述该方法的可行性。

数组中的重复数字

很容易观察到,如果对没有重复数字的数组进行排序,那么排序之后的数字i将会出现在下标为i的位置。

复现一下这个重排的大致过程:

扫一遍数组,到下标为i时,首先判断一下该处的值(假如为v)是不是等于i

如果答案是肯定的,那么接着往下扫描下一个数。

如果不是,再拿它和第v个数字进行比较,如果此时它(这里指的是i)和v相等,说明找到了一个重复数字。

如果它和第v个数字不相等,就将把第i个数和第v个数进行交换,也就是把v放到原本属于它的位置。

重复以上比较、交换的过程,直到程序结束。

有点懵??再来亿遍,用例模拟。

还是上面的官方给的测试用例:[2, 3, 1, 0, 2, 5, 3]


第一步:i=0,判断:nums[0]==2!=0交换:swap(nums[0],nums[nums[0]])即是交换(2,1)的位置。

结果:[1, 3, 2, 0, 2, 5, 3]满足条件【nums[i]不等于ii不变,继续扫描。


第二步:i=0,判断:nums[0]==1!=0交换:swap(nums[0],nums[nums[0]])即是交换(1,3)的位置。

结果:[3, 1, 2, 0, 2, 5, 3]满足条件【nums[i]不等于ii不变,继续扫描。


第三步:i=0,判断:nums[0]==3!=0交换:swap(nums[0],nums[nums[0]])即是交换(3,0)的位置。

结果:[0, 1, 2, 3, 2, 5, 3]满足条件【nums[i]不等于ii不变,继续扫描。


第四步:i=0,判断:nums[0]==0满足条件【nums[i]==i】此时[0, 1, 2, 3, 2, 5, 3]``````i++继续下一轮比较。


第五步:i=1,判断:nums[1]==1满足条件【nums[i]==i】此时[0, 1, 2, 3, 2, 5, 3]``````i++继续下一轮比较。


第六步:i=2,判断:nums[2]==2满足条件【nums[i]==i】此时[0, 1, 2, 3, 2, 5, 3]``````i++继续下一轮比较。


第七步:i=3,判断:nums[3]==3满足条件【nums[i]==i】此时[0, 1, 2, 3, 2, 5, 3]``````i++继续下一轮比较。


第八步:i=4,判断:nums[4]==2!=4交换:swap(nums[4],nums[nums[4]])即是交换(2,2)的位置。

注意,这里我们发现此时交换的数字都是2,不过前者的下标为i=4,而后者下标i=2,就是说,此时我们已经找到了数组中的一个重复值,因此进行返回即可,该用例答案为2,程序结束。

C++代码:
class Solution {
public:
    int findRepeatNumber(vector<int>& nums) {
		int n = nums.size();
		if(n<2) return -1;
		for(int i=0;i<n;i++)
		{
			if(nums[i]<0) return -1;
		}
		for(int i=0;i<n;i++)
		{
			while(nums[i]!=i)
			{
				if(nums[i]==nums[nums[i]])
				{
					return nums[i];
				}
				swap(nums[i],nums[nums[i]]);
			}
		}
		return -1;
    }
};
复杂度:

时间:O(n)。

空间:O(1)。

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

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

相关文章

高价硕士时代

今天翻到一篇关注读研的文章&#xff0c;里面列举了三个不同经历的研究生的故事&#xff0c;我感觉颜雨宁的经历更有代表性&#xff0c;于是将整理的笔记分享大家。 先来看看学硕和专硕的区别。 颜雨宁考的是专硕&#xff0c;她清楚地意识到这条路不会是平坦的。复旦大学的门槛…

打造人脸磨皮算法新标杆,满足企业多元化需求

高清视频和图片已成为企业展示形象、传递信息的重要载体&#xff0c;拍摄过程中难以避免的皮肤瑕疵和纹理不均等问题&#xff0c;常常让精美的画面失色。美摄科技凭借其领先的人脸磨皮算法解决方案&#xff0c;为企业提供了高效、精细的图像处理服务&#xff0c;让每一帧画面都…

【超简单实用】Zotero 7 内置pdf背景颜色更改插推荐以及安装

Zotero beta7 pdf 内置颜色更换 zetore 6 很多成熟的插件在 zetore 7都不能用了。版本回退看起来内置文章的注释会被消除&#xff0c;所以又不想退回去。前几个月在找beta 7 的pdf 护眼色的插件一直没有&#xff0c;今天终于发现了&#xff01;&#xff01;&#xff01;&#…

5分钟——快速搭建后端springboot项目

5分钟——快速搭建后端springboot项目 1. idea新建工程2. 构建pom.xml文件3. 构建application.yml配置文件4. 构建springboot启动类5. 补充增删改查代码6. 运行代码7. 下一章 1. idea新建工程 点击右上角新建一个代码工程 别的地方不太一样也不用太担心&#xff0c;先创建一个…

如何用微信发布考试成绩(如月考、期中、期末等)

自教育部《未成年人学校保护规定》颁布后,教育部明确表示:学校不得公开学生的考试成绩、排名等信息!同时学校应采取措施,便利家长知道学生的成绩等学业信息,对于教师来说,如何用微信发布考试成绩(如:月考、期中、期末等)就成了一道难题... 公开吧,会伤害到学生自尊心,甚至被投诉…

IDEA本地将镜像推送到coding制品仓库

创建制品仓库 假设仓库名称为docker 在IDEA 添加Docker 注册表 IDEA必须先安装docker插件 地址 用户名和密码就是coding的登录名和密码服务器 最好本地安装docker桌面版&#xff0c;更容易操作 测试连接成功 推送镜像到coding的docker制品仓库 选中某个镜像 鼠标右键 注册表…

保护你的网站:了解5种常见网络攻击类型及其防御方法

随着互联网的迅猛发展&#xff0c;针对网站的各种类型的网络攻击随之增加&#xff0c;网络攻击事件层出不穷&#xff0c;由此&#xff0c;如何保护网站安全成为每个网站所有者的重要议题。在下面的内容中&#xff0c;我们将探讨5种常见网络攻击类型及其防御方法&#xff0c;以帮…

oracle rman restore database的时候报错RMAN-06023: 没有找到数据文件1的副本来还原

一 问题描述 在oracle异地备份恢复测试数据库上执行restore database的时候报错&#xff1a; RMAN-06023: 没有找到数据文件1的副本来还原 可是我看备份明明都是存在的&#xff0c;而且已经执行了catalog start with命令。 有点奇怪的是catalog start with的时候&#xff0c…

数字化转型成功的企业到底是什么样的?

数字化转型成功的企业通常具备以下特征&#xff1a; 1、以客户为中心的业务模式&#xff1a;成功的数字化转型企业将客户放在业务模式的核心位置&#xff0c;通过提供个性化的服务和产品来满足客户需求。这种以客户为中心的模式能够带来更好的客户体验和忠诚度。 2、强大的数…

【数据结构】串(String)

文章目录 基本概念顺序存储结构比较当前串与串s的大小取子串插入删除其他构造函数拷贝构造函数扩大数组空间。重载重载重载重载[]重载>>重载<< 链式存储结构链式存储结构链块存储结构 模式匹配朴素的模式匹配算法(BF算法)KMP算法字符串的前缀、后缀和部分匹配值nex…

RuoYi-Vue-Plus (角色部门-数据权限 @DataPermission使用、自定义数据权限、数据权限拦截 、处理器解读)

本章主要是数据权限控制: 本章按照对部门id,用户id举例控制数据权限 功能: 1.支持自动注入 sql 数据过滤 2.查询、更新、删除 限制 3.支持自定义数据字段过滤 4.模板支持 spel 语法实现动态 Bean 处理 一、角色部门权限@DataPermission 1-使用及简介 权限范围五个 …

《环阳宗海逍遥游》

第一天:《六十八道拐》五月二日游兴浓&#xff0c;大观公园门囗逢。海埂西门再集合&#xff0c;蓝光城里意无穷。呈贡过后松茂过&#xff0c;阳宗镇上心欢融。宜良城中暂歇脚&#xff0c;六十八拐路难通。宜良住宿赏夜色&#xff0c;期待明朝再接龙。 第二天:《情人岛苗王峡行》…

用C#写一个读取pdf文档内容的库

安装这两个库&#xff0c;第二个库一定要安装否则有些pdf文件读取会出现异常 读取 using iText.Kernel.Pdf; using iText.Kernel.Pdf.Canvas.Parser; using iText.Kernel.Pdf.Canvas.Parser.Listener;namespace TestReadPdf {public static class PdfHelper{public static IE…

布局香港之零售小店篇 | 香港一人小企与连锁超市的竞争

近年来&#xff0c;内地品牌入驻香港市场开拓业务已成大势所趋。香港特区政府早前公布的「2023年有香港境外母公司的驻港公司按年统计调查」显示&#xff0c;2023年母公司在海外及内地的驻港公司数量高达9039家。内地品牌在香港的成功落地&#xff0c;不仅为香港市民带来了丰富…

「布道师系列文章」小红书黄章衡:AutoMQ Serverless 基石-秒级分区迁移

作者&#xff5c;黄章衡&#xff0c;小红书消息引擎研发专家 01 引言 Apache Kafka 因存算一体化架构&#xff0c;分区迁移依赖大量数据同步的完成&#xff0c;以一个 100MB/s 流量的 Kafka 分区为例&#xff0c;运行一天产生的数据量约为 8.2T&#xff0c;如果此时需要将该分…

【数据结构(邓俊辉)学习笔记】向量04——有序向量

文章目录 0.概述1.比较器2.有序性甄别3.唯一化3.1低效算法3.1.1实现3.1.2 复杂度3.1.3 改进思路3.2 高效算法3.2.1 实现3.2.2 复杂度 4.查找4.1统一接口4.2 语义定义4.3 二分查找4.3.1 原理4.3.2 实现4.3.3 复杂度4.3.4 查找长度4.3.5 不足 4.4 Fibonacci查找4.4.1 改进思路4.4…

AI-数学-高中-42导数的概念与意义

原作者视频&#xff1a;【导数】【一数辞典】1导数的概念与意义_哔哩哔哩_bilibili .a是加速度&#xff1b;

【Spring篇 | 补充】三级缓存解决循环依赖

文章目录 7.三级缓存解决循环依赖7.1何为循环依赖&#xff1f;7.2三级缓存解析7.3三级缓存解决循环依赖7.3.1实例化A7.3.2创建B的需求7.3.3实例化B7.3.4注入A到B7.3.5B创建完成7.3.6回溯至A7.3.7清理二级缓存 7.4为什么不能用二级缓存解决循环依赖&#xff1f; 7.三级缓存解决循…

【漏洞复现】通天星CMSV6车载监控平台ids SQL注入漏洞

漏洞描述&#xff1a; 通天星CMSV6车载定位监控平台拥有以位置服务、无线3G/4G视频传输、云存储服务为核心的研发团队&#xff0c;专注于为定位、无线视频终端产品提供平台服务&#xff0c;通天星CMSV6产品覆盖车载录像机、单兵录像机、网络监控摄像机、行驶记录仪等产品的视频…

微信小程序4~6章总结

目录 第四章 页面组件总结 4.1 组件的定义及属性 4.2 容器视图组件 4.2.1 view 4.2.2 scroll-view 4.2.3 swiper 4.3 基础内容组件 4.3.1 icon ​编辑 4.3.2 text 4.3.3 progress ​编辑 4.4 表单组件 4.4.1 button 4.4.2 radio 4.4.3 checkbox 4.4.4 switch …