刪除列表中重復元素的幾種方法


l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
# 版本一: 直接遍歷列表刪除
for el in l1:
    if l1.count(el) > 1:
        l1.remove(el)
print(l1)# 會漏刪,因為刪除一個元素后,后面的元素向前補位,導致緊跟的一個元素被跳過.
# 版本二: 通過遍歷索引刪除
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
for el in range(len(l1)):  # 此時len(l1)已經確定,不會隨着l1后面的變化而變化
    if l1.count(l1[el]) > 1:
        l1.remove(l1[el])
print(l1)  # 會報錯,因為刪除元素后導致l1的長度變短了,但是for遍歷的還是之前的索引長度,會導致索引超過范圍而報錯
# 版本三: 通過遍歷創建的切片來刪除原列表
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
for el in l1[:]:
    if l1.count(el) > 1:
        l1.remove(el) # 沒有問題,可以去重,但是無法保留原有的順序
print(l1)   
# 版本四: 用新列表記錄需要保留的元素
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
lst = []
for el in l1:
    if lst.count(el) < 1:
        lst.append(el)
print(lst)   # 沒有問題,也能保留原有順序,但是創建了新列表
# 版本五: 通過索引倒着刪除
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
for el in range(len(l1)-1, -1, -1):
    if l1.count(l1[el]) > 1:
        l1.pop(el)  # 沒有問題,且保留原順序
        # l1.remove(l1[el]) # 沒有問題,但是不能保留原有順序
        # del l1[el] # 這樣則會保留原有順序,小伙伴可以想一想為什么
print(l1)   
# 版本六: 通過遞歸函數刪除
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
def set_lst(lst):
    for el in lst:
        if lst.count(el) > 1:
            lst.remove(el)
            set_lst(lst)    # 每次開辟一個新函數,判斷上次被刪除了一個元素后的列表
    else:  # 直到最后,列表里的元素都是一個,運行了else
        return lst
print(set_lst(l1))  # 因為是從前面開始刪除的,所以不保留原有順序
'''
[1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 3, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 3, 3, 6, 6, 5, 5, 2, 2]
[1, 3, 6, 6, 5, 5, 2, 2]
[1, 3, 6, 5, 5, 2, 2]
[1, 3, 6, 5, 2, 2]
[1, 3, 6, 5, 2]   return lst = [1, 3, 6, 5, 2]
'''
# 版本七: 毫無疑問set()是最方便的
l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]
lst = list(set(l1))
print(lst)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM