python之数组元素去重

list = [1,2,13,1,31,21,13,1,3,13,1,31,211,1] # 具有重复元素的数组
list1= [] #创建一个新的数组来存储无重复元素的数组
for element in list :
  if(element not in list1):
    list1.append(element)

print list1

 

元素出现次数  https://www.cnblogs.com/kaibindirver/p/9866450.html

 

出重更好的方法 https://blog.csdn.net/weixin_44520259/article/details/89764254

 

一、用set方法去重后与原列表长度比较
lst=[1,3,5,3,4,4,2,9,6,7]
set_lst=set(lst)
#set会生成一个元素无序且不重复的可迭代对象,也就是我们常说的去重
if len(set_lst)==len(lst):
print('列表里的元素互不重复!')
else:
print('列表里有重复的元素!')
二、用append的方式把原列表中的元素添加到一个新列表,确保新列表里不存在重复的元素,然后比较两个列表
lst=[1,3,5,8,9,9,0,0,3,3]
new_list=[]

for i in lst:
if i not in new_list:
new_list.append(i)
#这样能确保新的列表里包含原列表里所有种类的元素,且元素互不重复

if len(new_list)==len(lst):
print('原列表里的元素互不重复!')
else:
print('原列表里有重复的元素!')
三、用fromkeys的方法创建一个字典,因为字典的键会自动去重,所以可以比较字典和原列表的长度,跟方法一很像
lst=[1,3,5,8,9,9,0,0]
dic={}.fromkeys(lst)
#这种方法建立字典,会把列表里的元素当做字典的键,由于字典的键不能重复,所以会自动去重
if len(dic)==len(lst):
print('列表里的元素互不重复!')
else:
print('列表里有重复的元素!')

posted @ 2020-04-09 20:41  凯宾斯基  阅读(5902)  评论(0编辑  收藏  举报