以下是一个解决方法的代码示例:
from itertools import combinations
def group_duplicates(nested_list):
# 将嵌套列表扁平化为一维列表
flat_list = [element for sublist in nested_list for element in sublist]
# 使用combinations函数找到所有重复元素的组合
duplicates = [tuple(sorted(pair)) for pair in combinations(flat_list, 2) if pair[0] == pair[1]]
# 创建一个字典,用于存储重复元素的分组
groups = {}
# 遍历所有重复元素的组合
for pair in duplicates:
# 获取组合中的两个元素
element1, element2 = pair
# 检查元素是否已经存在于字典中的某个分组中
if element1 in groups:
groups[element1].add(element2)
elif element2 in groups:
groups[element2].add(element1)
else:
# 创建一个新的分组,并将两个元素添加到分组中
groups[element1] = {element1, element2}
# 返回分组结果
return list(groups.values())
使用示例:
nested_list = [[(1, 2), (2, 3)], [(4, 5), (2, 3)], [(1, 2), (6, 7)]]
result = group_duplicates(nested_list)
print(result)
# 输出:[ {(1, 2), (2, 3)}, {(4, 5), (2, 3)}, {(1, 2), (6, 7)} ]
以上代码将嵌套列表扁平化为一维列表,然后使用combinations
函数找到所有重复元素的组合。接下来,使用字典存储重复元素的分组,最后返回分组结果。
上一篇:按两个值之间的差异对列表进行排序
下一篇:按两个重复值分割数据框架