搜索

首页  >  问答  >  正文

算法 - Python二维数组怎么求并集?

a=[[1,2,'g'],[2,4,'f']]
b=[[2,4,'f'],[1,2,'f']]

a和b的并集是

c=[[1,2,'g'],[2,4,'f'],[1,2,'f']]

无法使用set().union,怎么破?只能自己实现遍历么?

PHPzPHPz2887 天前519

全部回复(3)我来回复

  • 大家讲道理

    大家讲道理2017-04-17 17:28:55

    你可以用如下代码来实现:

    a=[[1,2,'g'],[2,4,'f']]
    b=[[2,4,'f'],[1,2,'f']]
    tmp = a + b
    c = [ (tmp[i]) for i in range(0, len(tmp)) if tmp[i] not in tmp[:i] ]
    

    检查结果:

    print c
    [[1, 2, 'g'], [2, 4, 'f'], [1, 2, 'f']]

    回复
    0
  • 天蓬老师

    天蓬老师2017-04-17 17:28:55

    可以这样:

    a=[[1,2,'g'],[2,4,'f']]
    b=[[2,4,'f'],[1,2,'f']]
    c=[list(i) for i in set(tuple(j) for j in a+b)]
    

    检查结果:

    print c
    [[2, 4, 'f'], [1, 2, 'f'], [1, 2, 'g']]
    

    回复
    0
  • ringa_lee

    ringa_lee2017-04-17 17:28:55

    直接使用集合操作肯定是不行的,因为列表里面的元素还是 列表,是一个可变对象,而集合操作的对象必须是不可变对象,因此如果想去重的话, 简单点的方法就是楼上的回复,转换为不可变对象tuple,从而再进行set去重。 如下,其实还是遍历。

    map(list,set(map(tuple, a + b)))

    回复
    0
  • 取消回复