Python习题:给出2*n + 1 个的数字,除其中一个数字之外其他每个数字均出现两次,找到这个数字。(比如:给出 [1,2,2,1,3,4,3],返回 4)

Posted felixqiang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python习题:给出2*n + 1 个的数字,除其中一个数字之外其他每个数字均出现两次,找到这个数字。(比如:给出 [1,2,2,1,3,4,3],返回 4)相关的知识,希望对你有一定的参考价值。

方法一:使用列表的count()方法取出单独的数

1 def find_single(num_list):
2     for n in num_list:
3         if num_list.count(n) == 1:
4             return n
5 
6 print(find_single([1,2,2,1,3,4,3]))

方法二:使用异或方法,简单快速

1 def find_single(num_list):
2     EOR = 0
3     for n in num_list:
4         EOR =EOR^n
5     return EOR
6 
7 print(find_single([1,2,2,1,3,4,3]))

 

以上是关于Python习题:给出2*n + 1 个的数字,除其中一个数字之外其他每个数字均出现两次,找到这个数字。(比如:给出 [1,2,2,1,3,4,3],返回 4)的主要内容,如果未能解决你的问题,请参考以下文章

习题:找回密码(高精度逆向模拟)

LintCode 82. 落单的数

Python练习题4.17水仙花数

Python练习题4.6输出前 n 个Fibonacci数

关于n个数里选k个的不同方法及一些思考

Python练习题4.2统计素数并求和