全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

生成指定长度的0-1组合数组:构造每行含x个1和x个0的所有唯一排列

本文介绍如何使用numpy与itertools高效生成所有长度为2x、且恰好包含x个1和x个0的二进制行向量组成的二维数组,适用于组合枚举、约束排列生成等场景。

您提供的示例中,当 x=2 时输出4行、每行4列(即 2*x=4),且每行恰好含两个1和两个0;同理,x=3 时每行6列、含三个1和三个0。但需注意:原始答案中使用的 np.column_stack([a, 1 - a]) 实际生成的是「前x位与后x位互补」的结构(如 [0,1,1,0]),这虽满足总长2x、总和为x,但并非穷举所有含x个1的组合——它仅覆盖了“前半段任意、后半段取反”的子集(共 2^x 种),而完整组合数应为 C(2x, x)(例如 x=3 时为 C(6,3)=20,但示例只列出8行)。

因此,正确解法应分为两类需求:

✅ 需求一:生成所有长度为 2x、恰含 x 个 1 的二进制向量(完整组合)

推荐使用 itertools.combinations 枚举 1 的位置索引,再用 NumPy 构造稀疏行:

import numpy as np
from itertools import combinations

def binary_arrays_with_x_ones(x):
    n = 2 * x
    # 生成所有从 [0, 1, ..., 2x-1] 中选 x 个位置置1的组合
    ones_positions = list(combinations(range(n), x))
    # 初始化全零数组
    arr = np.zeros((len(ones_positions), n), dtype=int)
    # 向每行对应位置填1
    for i, pos in enumerate(ones_positions):
        arr[i, list(pos)] = 1
    return arr

# 示例:x = 2 → 输出 6 行(C(4,2)=6),非原题所示4行
print(binary_arrays_with_x_ones(2))
# [[1 1 0 0]
#  [1 0 1 0]
#  [1 0 0 1]
#  [0 1 1 0]
#  [0 1 0 1]
#  [0 0 1 1]]
⚠️ 注意:原问题示例输出仅含4行(x=2)或8行(x=3),实为 “前x位任意,后x位为前x位的按位取反” 的特殊结构(即 a + (1-a) 拼接),其本质是 2^x 种模式,而非 C(2x,x)。若此结构即您的真实需求,则原始答案正确:

✅ 需求二:生成“前x位任意、后x位为其逻辑反”的数组(即 a | (1-a) 拼接)

from itertools import product
import numpy as np

def binary_arrays_complementary(x):
    # 生成所有长度为x的0-1组合
    a = np.array(list(product([0, 1], repeat=x)))
    # 拼接:前x位为a,后x位为1-a(逐元素取反)
    return np.hstack([a, 1 - a])

print(binary_arrays_complementary(2))
# [[0 0 1 1]
#  [0 1 1 0]
#  [1 0 0 1]
#  [1 1 0 0]]

该结果与您原始答案一致,但顺序和数值与题干示例不完全匹配(题干以 [1,0,1,0] 开头,而此处以 [0,0,1,1] 开头)。可通过排序或自定义排列调整,例如按字典序逆序或按特定模式筛选。

? 总结与建议

  • 若目标是数学意义上的所有含x个1的2x维二进制向量 → 用 combinations(range(2*x), x)(推荐,完备且直观);
  • 若目标是前后对称互补结构(如编码中的自反码) → 用 product([0,1], repeat=x) 拼接取反;
  • 避免 np.meshgrid 或盲目 product(*[[0,1]]*2x)(会生成 2^(2x) 行,远超需求,且需后过滤);
  • 对于大 x(如 x > 15),内存敏感场景建议使用生成器替代 list(...),或借助 numba/dask 加速。

最终选择取决于您的实际约束条件——请优先确认:是否必须严格满足“每行1的数量 = x”,还是仅需满足“前x位 + 后x位互为补集”这一更强对称性。


# 编码  # 排列  # numpy  # 您的  # 长度为  # 的是  # 穷举  # 这一  # 推荐使用  # 适用于  # 自定义  # 为其  # 所示 


相关文章: 网站设计制作企业有哪些,抖音官网主页怎么设置?  浅谈Javascript中的Label语句  建站主机助手选型指南:2025年热门推荐与高效部署技巧  建站之星客服服务时间及联系方式如何?  制作网站的基本流程,设计网站的软件是什么?  沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?  网站制作公司排行榜,四大门户网站排名?  如何在阿里云通过域名搭建网站?  如何选择美橙互联多站合一建站方案?  建站之星收费标准详解:套餐费用及年费价格表一览  太原网站制作公司有哪些,网约车营运证查询官网?  宝塔Windows建站如何避免显示默认IIS页面?  如何在Windows环境下新建FTP站点并设置权限?  如何通过VPS建站实现广告与增值服务盈利?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  宁波免费建站如何选择可靠模板与平台?  江苏网站制作公司有哪些,江苏书法考级官方网站?  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  北京企业网站设计制作公司,北京铁路集团官方网站?  网站制作费用多少钱,一个网站的运营,需要哪些费用?  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  零基础网站服务器架设实战:轻量应用与域名解析配置指南  南平网站制作公司,2025年南平市事业单位报名时间?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  python的本地网站制作,如何创建本地站点?  如何零成本快速生成个人自助网站?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  如何将凡科建站内容保存为本地文件?  如何快速建站并高效导出源代码?  制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?  h5在线制作网站电脑版下载,h5网页制作软件?  免费视频制作网站,更新又快又好的免费电影网站?  存储型VPS适合搭建中小型网站吗?  哈尔滨网站建设策划,哈尔滨电工证查询网站?  如何快速辨别茅台真假?关键步骤解析  如何用5美元大硬盘VPS安全高效搭建个人网站?  娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  如何确保FTP站点访问权限与数据传输安全?  如何选择高效便捷的WAP商城建站系统?  如何在Windows服务器上快速搭建网站?  建站之家VIP精选网站模板与SEO优化教程整合指南  定制建站如何定义?其核心优势是什么?  如何批量查询域名的建站时间记录?  深圳网站制作培训,深圳哪些招聘网站比较好?  在线制作视频网站免费,都有哪些好的动漫网站?  建站主机选哪种环境更利于SEO优化?  招商网站制作流程,网站招商广告语?  Swift中switch语句区间和元组模式匹配  全景视频制作网站有哪些,全景图怎么做成网页?  seo网站制作优化,网站SEO优化步骤有哪些? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。