子集枚举介绍

集合枚举的意思是从一个集合中找出它的所有子集。集合中每个元素都可以被选或不选,含有n个元素的集合总共有2^{n}个子集(包括全集和空集)

例如考虑集合A=\left \{ 1,2,3,4,5 \right \}和它的4个子集A_{1}=\left \{ 1,3,4,5 \right \}A_{2}=\left \{ 1,4,5 \right \}A_{3}=\left \{ 3 \right \}A_{4}=\left \{ 2,3 \right \},按照某个顺序,把全集A中的每个元素在每个子集中的出现状况用0(没出现)和1(出现了)表示出来。

A中元素12345二进制对应十进制
在A1中的出现情况1011111101a1=29
在A2中的出现情况1001110011a2=25
在A3中的出现情况0010000100a3=4
在A4中的出现情况0110000110a4=6

通过上面的表格就可以发现A的子集A1可以表示为一个二进制数11101,对应十进制变量a1=29,反之,这个数字也可以表示子集A1。注意,这边的集合是大写字母,集合对应的数字是小写字母。同理,A2可以表示为二进制数11001。此时找到了一种让子集对应于二进制数的很直观的方法

本例一共有5个元素,表示仅包含第i个元素的集合的数字可以使用位移运算构造,写成1<<(i-1),即2^{i-1},例如要找仅包含第3个元素的集合,那么找a=1<<(3-1),也就是4,此时对应的二进制数为00100,也就是集合{3}。而包含所有元素的全集可以表示成a=(1<<n)-1,空集表示为0。

一些常用的集合关系:

(1)并集:从元素选择角度来说,就是A2、A3包含的元素合并起来能够得到A1。可以发现A1的每一位都等于A2 or A3的结果。变成验证可得a1=a2|a3。只需要把表示两个子集的二进制数进行或运算即可得到两个子集的并集。

(2)交集:是指两个集合中同时存在的元素组成的集合。类似前面的并集运算,当需要两个子集的交集时,可以把表示两个子集的二进制数进行与运算,即a3=a1&a4。

(3)包含:集合A2的所有元素都在A1中出现,说明A1包含A2。易知A1并A2是A1,同时A1交A2是A2,也就是判断A1是否包含A2可以写成(a1|a2==a1)&&(a1&a2==a2)

(4)属于:是指某个元素在集合中,是包含的一种特殊情况--只需检查单独某项元素构成的集合是否是另一个集合的子集。一般地,可以使用户左移运算构造出那个仅含一项的集合,然后再和原集合取交,若不为空集,则命题为真。如果要判断第3个元素是否属于A1,可以写成1<<(3-1)&a1

(5)补集:是指全集去除了某个集合后剩下元素组成的集合。可以使用异或运算来表示集合对全集的补集,例如A2对于全集的补集就是A3。A2的补集可以表示为a^a2。

 注意:枚举子集的时间复杂度是O\left ( 2^{n} \right ),一般情况下1秒钟可以枚举包含20-30个元素的集合的子集。

具体的例题运用,可以参照此专栏的题解。

P1036 [NOIP2002 普及组] 选数题解-CSDN博客

P1157 组合的输出题解-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/456662.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数据开发】pyspark入门与RDD编程

【数据开发】pyspark入门与RDD编程 文章目录 1、pyspark介绍2、RDD与基础概念3、RDD编程3.1 Transformation/Action3.2 数据开发流程与环节 1、pyspark介绍 pyspark的用途 机器学习专有的数据分析。数据科学使用Python和支持性库的大数据。 spark与pyspark的关系 spark是一…

Mac OS中创建适合网络备份的加密镜像文件:详细步骤与参数选择

这篇文章提供了在Mac OS中创建适合网络备份的加密镜像文件的详细步骤&#xff0c;同时探讨了在选择相关参数时的关键考虑因素&#xff0c;以确保用户能够安全、高效地存储和保护重要数据。 创建步骤 在Mac OS Monterey中&#xff0c;你可以使用“磁盘工具”&#xff08;Disk …

C++_多态

目录 1、什么是虚函数 1.1 什么是虚函数重写 1.2 虚函数的继承 1.3 协变 1.4 析构函数的重写 2、override和final 2.1 final 2.2 override 3、纯虚函数/抽象类 3.1 接口继承和实现继承 4、多态的原理 前言&#xff1a; 在C中&#xff0c;多态指的是调用同一个类的…

深度学习图像分类相关概念简析+个人举例3(CNN相关补充,附详细举例代码1)

【1】激活函数&#xff08;Activation Function&#xff09;&#xff1a;在深度学习&#xff08;CNN&#xff09;中&#xff0c;激活函数用于引入非线性性质&#xff0c;帮助模型学习复杂的关系。常见的激活函数有ReLU、Sigmoid和Tanh等。 &#xff08;1&#xff09;ReLU激活函…

【HTML】MDN

文章目录 一、html元素1.1 <a>1.2 <abbr>1.3 <address>1.4<area>1.5 <article>1.6 <aside>1.7 <audio>1.8 <b>1.9 <base>1.10<bdi>1.11 <bdo>1.12 <blockquote>1.13 <body>1.14 <br>1.15…

如何在Linux部署Yearning并结合cpolar实现公网访问内网管理界面

文章目录 前言1. Linux 部署Yearning2. 本地访问Yearning3. Linux 安装cpolar4. 配置Yearning公网访问地址5. 公网远程访问Yearning管理界面6. 固定Yearning公网地址 前言 Yearning 简单, 高效的MYSQL 审计平台 一款MYSQL SQL语句/查询审计工具&#xff0c;为DBA与开发人员使用…

ERR_SSL_VERSION_OR_CIPHER_MISMATCH

我在namesilo买的域名&#xff0c;coludflare做的解析&#xff0c;华为云的SSL&#xff0c;用宝塔部署的SSL&#xff0c;访问https报错&#xff0c;http却正常&#xff1a; 报错&#xff1a;此网站无法提供安全连接www.hongkong.ioyunxin.top 使用了不受支持的协议。 ERR_SSL_…

22.HarmonyOS App(JAVA)位置布局PositionLayout使用方法

不常用 在PositionLayout中&#xff0c;子组件通过指定准确的x/y坐标值在屏幕上显示。(0, 0)为左上角&#xff1b;当向下或向右移动时&#xff0c;坐标值变大&#xff1b;允许组件之间互相重叠 布局方式 PositionLayout以坐标的形式控制组件的显示位置&#xff0c;允许组件相…

0-MQTT基础使用教程【学习】

文件路径 MQTT基础使用教程1. MQTT1.1 MQTT简介1.1.1 什么是MQTT1.1.2 设计原则1.1.3 应用领域1.2 MQTT协议相关概念1.2.1 MQTT协议实现方式1.2.2 MQTT协议中的方法1.3 消息服务质量QoS1.3.1 消息服务质量QoS三个等级1.3.2 发布与订阅QoS1.4 Topic通配符匹配规则2. EMQX2.1 EMQ…

深入理解Java中的二叉树

目录 一、什么是二叉树? 二、二叉树的主要类型 三、二叉树的实现 四、二叉树的应用 五、关于二叉树的题目 引言: 二叉树是计算机科学中常用的一种数据结构&#xff0c;它是由节点组成的层级结构&#xff0c;每个节点最多有两个子节点。在Java编程语言中&#xff0c;二…

时间回显+选择(年月日时分秒

一、获取某个时间 1、Date获取Date类型 <el-form-item label"时间" name"endTime"><el-date-picker type"datetime" v-model"editForm.endTime"></el-date-picker> </el-form-item> 效果如图&#xff1a; …

设计模式_责任链模式_Chain

案例引入 学校OA系统的采购审批项目: 需求是 采购员采购教学器材如果金额 小于等于5000&#xff08;0<x<5000&#xff09;&#xff0c;由教学主任审批如果金额 小于等于10000&#xff08;5000<x<10000&#xff09;&#xff0c;由院长审批如果金额 小于等于30000&…