首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >获取bool数组的所有排列

获取bool数组的所有排列
EN

Stack Overflow用户
提问于 2022-11-29 10:02:32
回答 1查看 46关注 0票数 1

我需要bool数组的所有排列,下面的代码效率很低,但是做我想做的事情:

代码语言:javascript
复制
from itertools import permutations
import numpy as np
n1=2
n2=3

a = np.array([True]*n1+[False]*n2)

perms = set(permutations(a))

然而,这是低效的,并失败的长数组。是否有更有效的实施?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-11-29 10:16:48

那么对真值的指数组合进行抽样呢:

代码语言:javascript
复制
from itertools import combinations
import numpy as np

a = np.arange(n1+n2)

out = [np.isin(a, x).tolist() for x in combinations(range(n1+n2), r=n1)]

输出:

代码语言:javascript
复制
[[True, True, False, False, False],
 [True, False, True, False, False],
 [True, False, False, True, False],
 [True, False, False, False, True],
 [False, True, True, False, False],
 [False, True, False, True, False],
 [False, True, False, False, True],
 [False, False, True, True, False],
 [False, False, True, False, True],
 [False, False, False, True, True]]
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74612253

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档