微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Python - 没有重复的列表列表的所有组合

如何解决Python - 没有重复的列表列表的所有组合

我想做一个字符串列表的组合,在组合结果中没有重复的字符串,但我不知道如何做到这一点。

例如:

# Input
pickup_list = [["a","b","c"],["d","e"],["a","c","f"]]
print(combinaison_function(pickup_list))

# Output
> [["a","d","f"],"e",["b","a"],...]

在示例中 ["a",”a"] 没有返回,因为 "a" 是重复的并且我想要这样做。

我想解决方案是使用 itertools 函数,但我不知道该怎么做。

感谢您提前回复

解决方法

这可以通过 itertools.product() 完成,然后过滤重复项。检查重复项的一种快速方法是强制转换为 set

comb_list = []
for comb in itertools.product(*pickup_list):
    if len(set(comb))==len(comb):
        comb_list.append(comb)

用你的 pickup_list 我得到:

[('a','d','c'),('a','f'),'e',('b','a'),('c','f')]

,

您可以制作自己的递归生成器:

def uCombo(L,used=None):
    if used is None: used = set()   # track used values
    if not L: yield [];return       # end of recursion
    for n in L[0]:                  # combine each unused value
        if n in used: continue      # with remaining sub-lists
        yield from ( [n]+c for c in uCombo(L[1:],used | {n}) )
    

输出:

pickup_list = [["a","b","c"],["d","e"],["a","c","f"]]
for combo in uCombo(pickup_list): print(combo)
                     
['a','c']
['a','f']
['a','f']
['b','a']
['b','c']
['b','f']
['c','a']
['c','f']

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?