如果你想使用循环,你将不得不使用你已经看过的列表或一组数字.然后在循环时你将检查,如果已经看到了数字,则使用in运算符.
seen = []
for number in myList:
if number in seen:
print "Number repeated!"
else:
seen.append(number)
set不允许重复,因此它非常适合这种算法.正如评论中所提到的,检查元素是否在集合中的时间复杂度对于平均情况(O(1))是不变的,因此如果你有很多数字,这会更有效.
seen = set()
for number in myList:
if number in seen:
print "Number repeated!"
seen.add(number) # won't duplicate
我会说最pythonic的方式是使用collections.Counter,但其他答案已经覆盖了这个.要使用内置函数,您可以生成一组使用generator expression和set出现多次的数字.
In [39]: seen = set()
In [40]: print list(set(x for x in myList if x in seen or seen.add(x)))
[1]
这里表达式将循环遍历myList中的所有值,并将它们添加到一个名为see的集合中,如果已经看到它们.最终,它会将结果集转换为列表并打印内容.