小编写了两种方法来去除列表中的重复元素。下面我会对这两种方法进行解释:
第一种方法:使用 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() 方法,后者在内部进行了优化以提高效率。然而,对于小型列表或简单场景,你的第二种方法也是可行的。