如何在 Python 中使用 for 循环查找数组中的重复元素?

2022-01-10 00:00:00 python duplicates

问题描述

我有一个包含重复元素的列表:

I have a list with duplicate elements:

 list_a=[1,2,3,5,6,7,5,2]

 tmp=[]

 for i in list_a:
     if tmp.__contains__(i):
         print i
     else:
         tmp.append(i)

我已经使用上面的代码在 list_a 中找到了重复的元素.我不想从列表中删除元素.

I have used the above code to find the duplicate elements in the list_a. I don't want to remove the elements from list.

但我想在这里使用 for 循环.通常我们使用的 C/C++ 我猜是这样的:

But I want to use for loop here. Normally C/C++ we use like this I guess:

 for (int i=0;i<=list_a.length;i++)
     for (int j=i+1;j<=list_a.length;j++)
         if (list_a[i]==list_a[j])
             print list_a[i]

我们如何在 Python 中这样使用?

how do we use like this in Python?

for i in list_a:
    for j in list_a[1:]:
    ....

我尝试了上面的代码.但它得到了错误的解决方案.我不知道如何增加 j 的值.

I tried the above code. But it gets solution wrong. I don't know how to increase the value for j.


解决方案

仅供参考,在python 2.7+,我们可以使用Counter

Just for information, In python 2.7+, we can use Counter

import collections

x=[1, 2, 3, 5, 6, 7, 5, 2]

>>> x
[1, 2, 3, 5, 6, 7, 5, 2]

>>> y=collections.Counter(x)
>>> y
Counter({2: 2, 5: 2, 1: 1, 3: 1, 6: 1, 7: 1})

唯一列表

>>> list(y)
[1, 2, 3, 5, 6, 7]

找到超过 1 次的项目

Items found more than 1 time

>>> [i for i in y if y[i]>1]
[2, 5]

仅找到一次的项目

>>> [i for i in y if y[i]==1]
[1, 3, 6, 7]

相关文章