转载:求一组数组中出现单次的数字类问题

本文介绍了三种寻找数组中唯一出现一次数字的算法:1. 数组中其他数字均出现两次,利用异或找出唯一数字;2. 数组中有两个数字各出现一次,通过将所有数字异或并找到不同位来划分并求解;3. 数组中除一个数字外其余均出现n次,使用特定方法找出该数字。

下面三个算法,觉得很有意思,转载的博客,学习了。

1.数组中,只出现一次的数字有一个,其它数字都出现了两次,找出这个数字,原文作者MoreWindows,很好得用到了异或的知识,很巧妙得解决了问题,转载自:http://blog.youkuaiyun.com/morewindows/article/details/7354571

2.与问题1不同的是,数组中有两个出现一次的数字,找出这两个数字。原文作者,通过对所有数字进行异或,最终结果的二进制位为1的,表示两个只出现一次的数字所不同的位,根据不同的位对原数组划分成两组,对两组采用与问题一样的算法,求出这两个数字。
转载自:http://blog.youkuaiyun.com/morewindows/article/details/8214003

3.数组中,除一个数字出现一次外,其余数字均出现了n次,找出这个数字,转载自:http://blog.youkuaiyun.com/morewindows/article/details/12684497

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值