将列表与交集合并

编程入门 行业动态 更新时间:2024-10-14 18:14:05
本文介绍了将列表与交集合并的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

鉴于:

g=[[], [], [0, 2], [1, 5], [0, 2, 3, 7], [4, 6], [1, 4, 5, 6], [], [], [3, 7]]

如何比较 g 中的每个列表,以便共享任何公共编号的列表可以合并到一个集合中?

How can I compare each list within g so that for lists sharing anyone common number can merge to a set?

例如0 存在于 g[2] 和 g[4]所以它们合并到一个集合 {0,2,3,7}

e.g. 0 exists in g[2] and g[4] so they merge to a set {0,2,3,7}

我尝试了以下方法,但它不起作用:

I have tried the following but it doesn't work:

for i in g: for j in g: if k in i == l in j: m=set(i+j)

我想制作尽可能大的集合.

I want to make the largest possible set.

推荐答案

作为一种快得多的方式,您可以先创建一个 len 大于一个 (s) .然后浏览您的列表并使用 union 功能!

As a much faster way You can first create a list of the set of items with len more than one (s) . then go through your list and update in place with union function !

s=map(set,g) def find_intersection(m_list): for i,v in enumerate(m_list) : for j,k in enumerate(m_list[i+1:],i+1): if v & k: m_list[i]=v.union(m_list.pop(j)) return find_intersection(m_list) return m_list

演示:

g=[[], [], [0, 2], [1, 5], [0, 2, 3, 7], [4, 6], [1, 4, 5, 6], [], [], [3, 7]] s=map(set,g) print find_intersection(s) [set([0, 2, 3, 7]), set([1, 4, 5, 6])] g=[[1,2,3],[3,4,5],[5,6],[6,7],[9,10],[10,11]] s=map(set,g) print find_intersection(s) [set([1, 2, 3, 4, 5, 6, 7]), set([9, 10, 11])] g=[[], [1], [0,2], [1, 5], [0, 2, 3, 7], [4, 6], [1, 4, 5, 6], [], [], [3, 7]] s=map(set,g) print find_intersection(s) [set([1, 4, 5, 6]), set([0, 2, 3, 7])]

以@Mark 的回答作为基准:

Benchmark with @Mark's answer :

from timeit import timeit s1="""g=[[], [], [0, 2], [1, 5], [0, 2, 3, 7], [4, 6], [1, 4, 5, 6], [], [], [3, 7]] sets = [set(i+j) for i in g for j in g if i!=j and (set(i) & set(j))] """ s2="""g=[[], [], [0, 2], [1, 5], [0, 2, 3, 7], [4, 6], [1, 4, 5, 6], [], [], [3, 7]] s=map(set,g) def find_intersection(m_list): for i,v in enumerate(m_list) : for j,k in enumerate(m_list[i+1:],i+1): if v & k: s[i]=v.union(m_list.pop(j)) return find_intersection(m_list) return m_list """ print ' first: ' ,timeit(stmt=s1, number=100000) print 'second : ',timeit(stmt=s2, number=100000) first: 3.8284008503 second : 0.213887929916

更多推荐

将列表与交集合并

本文发布于:2023-11-29 12:23:54,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1646384.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:列表

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!