版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u013003827/article/details/84317087
在python相关职位的面试过程中,会对列表list的去重进行考察。(注意有时会要求保证去重的顺序性)
方法1:直观方法
思路:先建立一个新的空列表,通过遍历原来的列表,再利用逻辑关系not in 来去重
代码:
#coding:utf-8
ll = [1, 2, 3, 3, 4, 5, 6, 6, 6,7,8,8,9,10,10]
new_ll = []
for i in ll:
if i not in new_ll:
new_ll.append(i)
print(new_ll)
输出:
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
**总结:**这样可以做出来,但是过程不够简单。但是此方法保证了列表的顺序性。
方法2:利用set的自动去重功能
**思路:**将列表转化为集合再转化为列表,利用集合的自动去重功能,简单快速。缺点是:使用set方法无法保证去重后的顺序。
代码:
ll = [11,22,33,44,11,22]
ll = list(set(ll))
print(ll)
输出:
[33, 11, 44, 22]
虽然set方法不能保证去重后的顺序,但是可以通过列表中索引(index)的方法保证去重后的顺序不变,如下:
ll = [11,22,33,44,11,22]
new_ll = list(set(ll))
new_ll.sort(key=ll.index)
print(new_ll)
输出:
[11, 22, 33, 44]
总结:python的set和其他语言类似,是一个无序不重复元素集