用Python实现列表元素去重

小编写了两种方法来去除列表中的重复元素。下面我会对这两种方法进行解释:

第一种方法:使用 set()
set() 函数可以将列表转换为一个集合。集合(set)是一个无序的不重复元素序列。因此,当你将列表转换为集合时,任何重复的元素都会被自动去除。

def pythonit():  
    lst = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 3, 5, 6, 9]  
    print(set(lst))  
  
pythonit()  # 输出: {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}

请注意,集合是无序的,所以打印出来的结果可能与原始列表中的顺序不同。如果你需要保持元素的顺序,那么这个方法可能不适用。

第二种方法:创建一个空列表并遍历原列表
这种方法通过遍历原始列表,检查每个元素是否已存在于一个新列表中。如果不存在,则将其添加到新列表中。这样可以确保新列表中没有重复的元素。

def pythonit():  
    lst = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 3, 5, 6, 9]  
    a = []  
    for i in lst:  
        if i not in a:  
            a.append(i)  
    print(a)  
  
pythonit()  # 输出: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

这种方法保持了原始列表中元素的顺序,但效率可能不是最高的,特别是在列表很长时,因为对于每个元素,都需要检查它是否已在新列表中(这是一个O(n)操作)。

对于去除重复元素并保持顺序,更有效的方法是使用列表推导式结合 if x not in 检查,或者使用 dict.fromkeys() 方法,后者在内部进行了优化以提高效率。然而,对于小型列表或简单场景,你的第二种方法也是可行的。

Python列表元素去重

我来吐槽

*

*