Python实现列表删除重复元素的三种常用方法分析
本文实例讲述了Python实现列表删除重复元素的三种常用方法。分享给大家供大家参考,具体如下:
给定一个列表,要求删除列表中重复元素。
listA=['python','语','言','是','一','门','动','态','语','言']
方法1,对列表调用排序,从末尾依次比较相邻两个元素,遇重复元素则删除,否则指针左移一位重复上述过程:
defdeleteDuplicatedElementFromList(list): list.sort(); print("sortedlist:%s"%list) length=len(list) lastItem=list[length-1] foriinrange(length-2,-1,-1): currentItem=list[i] ifcurrentItem==lastItem: list.remove(currentItem) else: lastItem=currentItem returnlist
方法2,设一临时列表保存结果,从头遍历原列表,如临时列表中没有当前元素则追加:
defdeleteDuplicatedElementFromList2(list): resultList=[] foriteminlist: ifnotiteminresultList: resultList.append(item) returnresultList
方法3,利用python中集合元素惟一性特点,将列表转为集合,将转为列表返回:
defdeleteDuplicatedElementFromList3(listA): #returnlist(set(listA)) returnsorted(set(listA),key=listA.index)
执行结果:
print(deleteDuplicatedElementFromList(listA)) #sortedlist:['python','一','动','态','是','言','言','语','语','门'] #['python','一','动','态','是','言','语','门'] print(deleteDuplicatedElementFromList2(listA)) #['python','语','言','是','一','门','动','态'] print(deleteDuplicatedElementFromList3(listA)) #['python','语','言','是','一','门','动','态']
分析:
方法1,逻辑复杂,临时变量保存值消耗内存,返回结果破坏了原列表顺序,效率最差
方法2,直接调用append方法原处修改列表,逻辑清晰,效率次之
方法3,极度简洁,使用python原生方法效率最高
PS:这里再为大家提供几款去重复工具供大家参考使用:
在线去除重复项工具:
http://tools.jb51.net/code/quchong
在线文本去重复工具:
http://tools.jb51.net/aideddesign/txt_quchong
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python列表(list)操作技巧总结》、《Python数组操作技巧总结》、《Python字符串操作技巧汇总》、《Python函数使用技巧总结》、《Python入门与进阶经典教程》及《Python数据结构与算法教程》
希望本文所述对大家Python程序设计有所帮助。