草庐IT

leetcode刷题之消失的数字(超详解刷爆力扣)

从小生开始 2023-09-01 原文

大家好啊,我是小生啊🙈🙈🙈
从今天开始小生将会和大家一起刷题,从今天开始小生也会开辟新的专栏。😜😜😜

下一篇比这篇质量高多啦,哈哈,大家快来看啦~~~
多种方法刷爆力扣———轮转数组🥳🥳🥳.

🌞🌞🌞 让我们多种方法解题练习,刷爆力扣,冲冲冲


力扣练习:消失的数字🏃🏃🏃

一.🏠题目描述

兄弟们,废话不多说直接看题:🙉🙉🙊

示例1:
输入:[3,0,1]
输出:2

示例2:
输入:[9,6,4,2,3,5,7,0,1]
输出:8

二.🏠题目分析

这道题目看似比较简单,实际我们在其中还是可以学到很多的知识。我们先标识一下题目中比较重要的点~~🙉🙉

由图片分析可得,该题目对算法由一定的要求,首先我们得明白时间复杂度为O(N)算法意味着什么。我们先来看看算法的时间复杂度对比图,在大概了解到题目所需要的算法优化程度后,我们就可以着手来做题目啦😎😎😎


三.🏠解决方法

1.🚀思路一:先排序再查找

既然是0~n内的整数,且仅仅缺少了一个整数,那么我们就可以先对该数组进行排序,再检验相邻下标的元素是否相差为1,理论上便可以得出最后的结果。
在这里小生不得不提醒大家,排序的复杂度是相当高的,即便是最复杂度最小的快排,在这个程序内也不合适。我们可以通过图片来认识😯😯😯

由该表可知,当我们使用效率最高的排序且考虑最坏的情况时,复杂度为N*log2(N),显然在这个题目中超出了复杂度的要求,因此,这种思路虽然是最直接的但是一定会超时。别慌,我们再想想其他办法。

2.🚀思路二:逆推相减

具体问题具体分析,既然我们该数组存储的是0~n里面的整数且只缺少了一个整数,那我们可以用将0 ~ n所有的整数相加,再把该数组中的整数相加最后两个和向减即可。💪💪💪

但是我们可以举一反三,如果题目更改一下,缺失的并非一个数字而是多个数字呢?那这种方法是不是就不起作用啦?这种方法还是不错的,那有没有更加普适性的方法呢?大家可以思考一下

3.🚀思路三:异或运算求解

位与位异或,相同为0,不相同为1.同时,因为异或是位与位进行计算的,所以异或的顺序不重要,结果是一样的,由此,在我们这个题目中,我们可以通过一下思路实现:
因为异或相同得零,不同得1,所以使用一个变量将数组中所有元素异或,然后再和1到n进行异或,得到的就是消失的数字😎😎😎

四.🏠代码实现

1.🚀方法一代码详解

定义两个变量,一个通过循环存储数组所有元素的和,一个通过循环存储1~n所有数字的和,最后相减即可。
代码如下👇👇👇👇

int Missingnum(int* nums, int numsSize)
{
	int sum1 = 0;
	int sum2 = 0;
	//求出数组所有元素之和
	for (int i = 0; i < numsSize; i++)
	{
		sum1 += nums[i];
	}
	//求出1~n所有元素之和
	for (int i = 0; i < numsSize + 1; i++)
	{
		sum2 += i;
	}
	return sum2 - sum1;
}

2.🚀方法二代码详解

定义一个初始化为0的变量,依次与该数组和1~n的每一个数字异或,最后留下来的便是所求的数字了
直接看代码👇👇👇👇

int Missingnum(int* nums, int numsSize)
{
	int tmp = 0;
	//依次与数组的每一个元素异或
	for (int i = 0; i < numsSize; i++)
	{
		tmp ^= nums[i];
	}
	//依次与1~n个数字异或
	for (int i = 0; i < numsSize +1; i++)
	{
		tmp ^= i;
	}
	return tmp;
}
 

五. 🏠结语

小生会不断更新力扣上的题解,希望大家多多支持呀别忘了三连哦,你们的鼓励就是小生最大的动力,下一篇质量更高哦!! 快来看!!
三种方法刷爆力扣——轮转数组
😎😎😎

有关leetcode刷题之消失的数字(超详解刷爆力扣)的更多相关文章

  1. ruby - 查找字符串中的内容类型(数字、日期、时间、字符串等) - 2

    我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s

  2. 区块链之加解密算法&数字证书 - 2

    目录一.加解密算法数字签名对称加密DES(DataEncryptionStandard)3DES(TripleDES)AES(AdvancedEncryptionStandard)RSA加密法DSA(DigitalSignatureAlgorithm)ECC(EllipticCurvesCryptography)非对称加密签名与加密过程非对称加密的应用对称加密与非对称加密的结合二.数字证书图解一.加解密算法加密简单而言就是通过一种算法将明文信息转换成密文信息,信息的的接收方能够通过密钥对密文信息进行解密获得明文信息的过程。根据加解密的密钥是否相同,算法可以分为对称加密、非对称加密、对称加密和非

  3. Python 刷Leetcode题库,顺带学英语单词(31) - 2

    ValidPalindromeGivenastring,determineifitisapalindrome,consideringonlyalphanumericcharactersandignoringcases. [#125]Example:"Aman,aplan,acanal:Panama"isapalindrome."raceacar"isnotapalindrome.Haveyouconsiderthatthestringmightbeempty?Thisisagoodquestiontoaskduringaninterview.Forthepurposeofthisproblem

  4. ruby-on-rails - environment.rb 中设置的常量在开发模式中消失 - 2

    了解Rails缓存如何工作的人可以真正帮助我。这是嵌套在Rails::Initializer.runblock中的代码:config.after_initializedoSomeClass.const_set'SOME_CONST','SOME_VAL'end现在,如果我运行script/server并发出请求,一切都很好。然而,在我的Rails应用程序的第二个请求中,一切都因单元化常量错误而变得糟糕。在生产模式下,我可以成功发出第二个请求,这意味着常量仍然存在。我已通过将以上内容更改为以下内容来解决问题:config.after_initializedorequire'some_cl

  5. ruby - 将n维数组的每个元素乘以Ruby中的数字 - 2

    在Ruby中,是否有一种简单的方法可以将n维数组中的每个元素乘以一个数字?这样:[1,2,3,4,5].multiplied_by2==[2,4,6,8,10]和[[1,2,3],[1,2,3]].multiplied_by2==[[2,4,6],[2,4,6]]?(很明显,我编写了multiplied_by函数以区别于*,它似乎连接了数组的多个副本,不幸的是这不是我需要的)。谢谢! 最佳答案 它的长格式等价物是:[1,2,3,4,5].collect{|n|n*2}其实并没有那么复杂。你总是可以使你的multiply_by方法:c

  6. Ruby 的数字方法性能 - 2

    我正在使用Ruby解决一些ProjectEuler问题,特别是这里我要讨论的问题25(Fibonacci数列中包含1000位数字的第一项的索引是多少?)。起初,我使用的是Ruby2.2.3,我将问题编码为:number=3a=1b=2whileb.to_s.length但后来我发现2.4.2版本有一个名为digits的方法,这正是我需要的。我转换为代码:whileb.digits.length当我比较这两种方法时,digits慢得多。时间./025/problem025.rb0.13s用户0.02s系统80%cpu0.190总计./025/problem025.rb2.19s用户0.0

  7. ruby - 按数字(从大到大)然后按字母(字母顺序)对对象集合进行排序 - 2

    我正在构建一个小部件来显示奥运会的奖牌数。我有一个“国家”对象的集合,其中每个对象都有一个“名称”属性,以及奖牌计数的“金”、“银”、“铜”。列表应该排序:1.首先是奖牌总数2.如果奖牌相同,按类型分割(金>银>铜,即2金>1金+1银)3.如果奖牌和类型相同,则按字母顺序子排序我正在用ruby​​做这件事,但我想语言并不重要。我确实找到了一个解决方案,但如果感觉必须有更优雅的方法来实现它。这是我做的:使用加权奖牌总数创建一个虚拟属性。因此,如果他们有2个金牌和1个银牌,加权总数将为“3.020100”。1金1银1铜为“3.010101”由于我们希望将奖牌数排序为最高的,因此列表按降序排

  8. ruby-on-rails - rails 中的正则表达式匹配 [\w] 和 "-"但不匹配数字 - 2

    我想为名字验证编写一个正则表达式。正则表达式应包括所有字母(拉丁/法语/德语字符等)。但是我想从中排除数字并允许-。所以基本上它是\w(减)数(加)-。请帮忙。 最佳答案 ^[\p{L}-]+$\p{L}匹配anykindofletterfromanylanguage. 关于ruby-on-rails-rails中的正则表达式匹配[\w]和"-"但不匹配数字,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c

  9. ruby-on-rails - 将数字字符串转换为数字数组 - 2

    在我的应用程序中,我有一个文本字段,用户可以在其中输入类似这样的内容"1,2,3,4"存储到数据库中。现在,当我想使用内部数字时,我有两个选择:"1,2,3,4".split(',')或string.scan(/\d+/)do|x|a两种方式我都得到一个像这样的数组["1","2","3","4"]然后我可以通过在每个数字上调用to_i来使用这些数字。有没有更好的方法可以转换"1,2,3"to[1,2,3]andnot["1","2","3"] 最佳答案 str.split(",").map{|i|i.to_i}但是这个想法对你来说

  10. ruby - 递归地将所有数字字符串转换为 Ruby 哈希中的整数 - 2

    我有一个随机大小的散列,它可能有类似"100"的值,我想将其转换为整数。我知道我可以使用value.to_iifvalue.to_i.to_s==value来做到这一点,但我不确定我将如何在我的散列中递归地做到这一点,考虑到一个值可以是一个字符串,或一个数组(哈希或字符串),或另一个哈希。 最佳答案 这是一个非常简单的递归实现(尽管必须同时处理数组和散列会增加一些技巧)。deffixnumifyobjifobj.respond_to?:to_i#IfwecancastittoaFixnum,doit.obj.to_ielsifobj

随机推荐