我在这里看到了一些非常相关的问题,但是他们的答案对我来说不起作用。我有一个列表列表,其中有些子列表是重复的,但是它们的元素可能会混乱。例如
g = [[1, 2, 3], [3, 2, 1], [1, 3, 2], [9, 0, 1], [4, 3, 2]]
根据我的问题,输出应该自然是:
g = [[1,2,3],[9,0,1],[4,3,2]]
我试过了,set
但是只删除了那些相等的列表(我认为它应该起作用,因为根据定义,集合是无序的)。我访问过的其他问题仅包含示例,这些示例具有完全重复或重复的列表,例如:Python:如何删除列表中的重复列表?。目前,输出顺序(对于列表和子列表)不是问题。
(ab)使用列表版本的副作用版本:
seen = set()
[x for x in g if frozenset(x) not in seen and not seen.add(frozenset(x))]
Out[4]: [[1, 2, 3], [9, 0, 1], [4, 3, 2]]
对于那些不喜欢以这种方式使用副作用的人(与我不同):
res = []
seen = set()
for x in g:
x_set = frozenset(x)
if x_set not in seen:
res.append(x)
seen.add(x_set)
之所以将frozenset
s添加到集合中,是因为您只能将可哈希对象添加到中set
,而vanilla set
s不可哈希。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句