这个可简单可复杂。
简单的:利用集合
a = list(set(a)) #这样就可以了,是不是很简单
复杂的:
就是先对列表排序,然后比较相邻元素是否相同,相同的则删除后面的。大体算法思路,代码自己写吧
当然还有其他的算法...
-----------------------------------------------------------------------------------
额, 不好意思,看错了
def Q(a):
aa=[]
for i in a:
if a.count(i)==1:
aa.append(i)
return aa
这个就可以了,利用 list.count(obj) 计算obj在list中出现的次数进行判断
使用列表推导,只保留元素个数等于1的
a = ['a', 'b', 'c', 'd', 'a', 'a']
b = [x for x in a if a.count(x) == 1]
print b
列表推导中的x for x in a if a.count(1) == 1和下面的for循环等价,不过更简洁:
b = []
for x in a:
if a.count(x) == 1:
b.append(x)
print b
代码如下:
oldList = ['a','b','c','d','a','a']
newList = []
for letter in oldList:
if letter not in newList:
newList.append(letter)
print newList
运行结果:
['a', 'b', 'c', 'd']
a=["a","b","c","c","d"]
print("删除前的list:\n",a)
b={}
b=b.fromkeys(a)
a=list(b.keys())
print("删除后的list:\n",a)
来来来,看我的
for i in a[:]:
if i=='a':
a.remove(i)
是不是很简单?不过有大神能再解释下深层原因,让我们知其所以然就更好了