LeetCode如何找出只出现一次的数字
发表于:2025-01-24 作者:千家信息网编辑
千家信息网最后更新 2025年01月24日,这篇文章主要为大家展示了"LeetCode如何找出只出现一次的数字",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"LeetCode如何找出只出现一次的数字"
千家信息网最后更新 2025年01月24日LeetCode如何找出只出现一次的数字思路一 : 集合差值 思路二 : 位运算 当然,对集合进行遍历,通过哈希表记录每个数字出现次数的方法也是可以的,时空复杂度也都是O(N),代码与Day 5思路一一致,此处不再赘述。
这篇文章主要为大家展示了"LeetCode如何找出只出现一次的数字",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"LeetCode如何找出只出现一次的数字"这篇文章吧。
1
题目描述
给定一个非空整数数组,只有一个数字出现一次,其余出现三次,找出只出现一次的数字。如输入[3,4,5,4,3,3],输出5。
2
解题
对集合进行切片,生成三个集合,找到与另外两个集合不同的集合缺少的数字。如集合[2,2,3,2],先对集合进行排序,得到[2,2,2,3],通过切片生成集合[2,3]、[2]、[2],比较集合之间元素差别,得到输出结果3。
class Solution: def singleNumber(self, nums: List[int]) -> int: nums.sort() a=len(set(nums[::2])) b=len(set(nums[1::2])) if a==b: return list(set(nums[::3]) - set(nums[2::3]))[0] else: return list(set(nums[::3]) - set(nums[1::3]))[0]
通过set方法时空复杂度都是O(N),位运算可以使得空间复杂度降为O(1)。在LeetCode刷题DAY 5:只出现一次的数字中使用的"异或"其实就是同一状态出现两次则归零,即0->1->10=0的变化,在本题中则是要让同一状态出现三次归零,即00->01->10->11=00,可见这里需要用两个bit进行状态记录。
这里需要注意的是,要对two、one两位分别计算。对于one,当two=1时,不管输入是什么下一步的one都为0,当two=0时,输入1则one=~one,输入0则one不变。对于two,依赖于one变化后的状态,one新状态为1时,two则为0,one新状态为0时,输入1则two=~two,输入0则不变。因为出现三次就归零,所以one最后保留的是只出现了一次的值。
class Solution: def singleNumber(self, nums: List[int]) -> int: one,two = 0,0 for i in nums: one = one^i & ~two two = two^i & ~one return one
以上是"LeetCode如何找出只出现一次的数字"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
数字
状态
输入
复杂
内容
复杂度
思路
篇文章
两个
方法
时空
变化
学习
帮助
生成
输出
运算
不同
一致
三个
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
眼动成人数据库
设立网络安全学科高校
单位网络安全等级保护自查
北京ios软件开发设计
软件开发语言类别
国情调查数据库
无线网络安全监控器
视频管理服务器的设置
网络安全突发事件有哪些
网络安全防止病毒
淘宝商品分类数据库
重庆浪潮服务器维修点
税务开票访问数据库错误
iso网络安全模型
黑龙江网络技术人员
淮安营销软件开发价格
数据中心网络安全应急响应
网络安全类别b类
服务器主机组装视频
东莞专业冷库软件开发
梦幻手游哪个服务器最强
安全教育课网络安全
防疫安全网络安全发言稿
数据库原理及技术钱雪忠
网络安全行业技能图
软件开发机构排行
维护服务器工作怎么样
服务器该怎么选
云计算和数据库哪个适合女生
pda软件开发服务