集合的所有子集的算法

转载自:http://blog.csdn.net/yzl20092856/article/details/39995085

求集合的所有子集的算法

对于任意集合A,元素个数为n(空集n=0),其所有子集的个数为2^n个

如集合A={a,b,c},其子集个数为8;对于任意一个元素,在每个子集中,

要么存在,要么不存在,对应关系是:

a->1或a->0

b->1或b->0

c->1或c->0

映射为子集:

(a,b,c)

(1,1,1)->(a,b,c)

(1,1,0)->(a,b  )

(1,0,1)->(a,  c)

(1,0,0)->(a     )

(0,1,1)->(  b,c)

(0,1,0)->(  b   )

(0,0,1)->(     c)

(0,0,0)->@(@表示空集)

算法(1):

观察以上规律,与计算机中数据存储方式相似,故可以通过一个整型数(int)与

集合映射000...000 ~ 111...111(0表示有,1表示无,反之亦可),通过该整型数

逐次增1可遍历获取所有的数,即获取集合的相应子集。

在这里提一下,使用这种方式映射集合,在进行集合运算时,相当简便,如

交运算对应按位与&,{a,b,c}交{a,b}得{a,b}<--->111&110==110

并运算对应按位或|

差运算对应&~

算法(2):

设函数f(n)=2^n (n>=0),有如下递推关系f(n)=2*f(n-1)=2*(2*f(n-2))

由此可知,求集合子集的算法可以用递归的方式实现,对于每个元素用一个映射列表marks,标记其

在子集中的有无

很显然,在集合元素个数少的情况下,算法(1)优于算法(2),因为只需通过加法运算,便能映射

出子集,而算法(2)要递归调用函数,速度稍慢。但算法(1)有一个严重缺陷,集合的个数不能大于在

计算机中一个整型数的位数,一般计算机中整型数的为32位。对于算法(2)就没这样限制。

 

1.	template<class T>  
2.	void print(T a[],int mark,int length)    
3.	{    
4.	    bool allZero=true;    
5.	    int limit=1<<length;    
6.	    for(int i=0;i<length;++i)    
7.	    {    
8.	        if(((1<<i)&mark)!=0)      //mark第i+1位为1,表示取该元素    
9.	        {    
10.	            allZero=false;    
11.	            cout<<a[i]<<" ";    
12.	        }    
13.	    }    
14.	    if(allZero==true)    
15.	    {    
16.	        cout<<"@";    
17.	    }    
18.	    cout<<endl;    
19.	}  
20.	  
21.	template<class T>  
22.	void subset(T a[],int length)    
23.	{    
24.	    if(length>31) return;    
25.	    int lowFlag=0;                  //对应000...000    
26.	    int highFlag=(1<<length)-1;       //对应111...111    
27.	    for(int i=lowFlag;i<=highFlag;++i)    
28.	    {    
29.	        print(a,i,length);    
30.	    }  
31.	  
32.	}  
算法二:

template<class T>    
void print(T a[],bool marks[],int length)    
{    bool allFalse=true;    for(int i=0;i<length;++i)    {    if(marks[i]==true)    {    allfalse=false;    cout<<a[i]<<"  ";    }    }    if(allFalse==true)    {    cout<<"@";    }    cout<<endl;  }  template<class T>  
void subset(T a[],bool marks[],int m,int n,int length)    
{    if(m>n)    {    print(a,marks,length);    }    else    {    marks[m]=true;    subset(a,marks,m+1,n,length);   marks[m]=false;    subset(a,marks,m+1,n,length);   }  }  


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

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

相关文章

经济学人: Arm,孙正义手中的这只水晶球正在帮助他预测未来

来源&#xff1a;经济学人编译&#xff1a;机器之能 高璇摘要&#xff1a;除了看中 Arm 出色的盈利能力&#xff0c;对于孙正义来说&#xff0c;Arm 更像是未来计算应用的信息交换中心&#xff0c;虽然不能给软银具体的投资建议&#xff0c;但 Arm 确实可以告诉孙正义有前景、值…

C++开源项目

转载自&#xff1a;http://www.cnblogs.com/liinux/ 程序员要站在巨人的肩膀上&#xff0c;C拥有丰富的开源库&#xff0c;这里包括&#xff1a;标准库、Web应用框架、人工智能、数据库、图片处理、机器学习、日志、代码分析等。 github:https://github.com/fffaraz/awesome-…

深入浅出浮点数

1. 什么是浮点数在计算机系统的发展过程中&#xff0c;曾经提出过多种方法表达实数。典型的比如相对于浮点数的定点数&#xff08;Fixed Point Number&#xff09;。在这种表达方式中&#xff0c;小数点固定的位于实数所有数字中间的某个位置。货币的表达就可以使用这种方式&am…

深度解析2019中国机器人行业年会主旨报告:把脉中国机器人发展,助力产业创新与协作共融...

来源&#xff1a;机器人大讲堂摘要&#xff1a;1月10日&#xff0c;由机器人大讲堂联合主办的2019中国机器人行业年会在北京盛大开幕。2018年经济下行趋势明显&#xff0c;迫使我们能沉下心来面对之前异常火爆的机器人市场&#xff0c;整个行业开始变得跌跌撞撞&#xff0c;很多…

矩阵的物理意义

转载自&#xff1a;http://blog.csdn.net/NightkidLi_911/article/category/2428737 &#xff08;一&#xff09; 如果不熟悉线性代数的概念&#xff0c;要去学习自然科学&#xff0c;现在看来就和文盲差不多。”&#xff0c;然而“按照现行的国际标准&#xff0c;线性代数是…

一些看起来简单做起来难的程序员笔试面试题集锦

1、判断三个bool值中是否至少有两个bool为真&#xff1f; 此题有几种不同的解法 &#xff08;1&#xff09;传统解法 bool leastTwo(bool a, bool b, bool c){return (a&&b) || (b&&c) || (c&&a); }&#xff08;2&#xff09;如果学过电路的可以考虑利…

如何防止基因编辑技术突破底线:警惕科学狂人再现

作者&#xff1a;胡丹萍 吴跃伟 刘楚来源&#xff1a;澎湃新闻从前隅于学界的基因编辑一词&#xff0c;在2018年&#xff0c;有如一声惊雷传入寻常百姓家。DNA和基因是生物体的核心代码&#xff0c;使用一组生物分子像剪刀或橡皮一样精确地改变基因序列即基因编辑技术。几十年来…

二分查找算法java

二分查找又称折半查找&#xff0c;它是一种效率较高的查找方法。 折半查找的算法思想是将数列按有序化(递增或递减)排列&#xff0c;查找过程中采用跳跃式方式查找&#xff0c;即先以有序数列的中点位置为比较对象&#xff0c;如果要找的元素值小于该中点元素&#xff0c;则将待…

opencv简单的矩阵操作

OpenCV的基本矩阵操作与示例 OpenCV中的矩阵操作非常重要&#xff0c;本文总结了矩阵的创建、初始化以及基本矩阵操作&#xff0c;给出了示例代码&#xff0c;主要内容包括&#xff1a; 创建与初始化矩阵加减法矩阵乘法矩阵转置矩阵求逆矩阵非零元素个数矩阵均值与标准差矩阵全…

中科院院士丁汉:数字化制造、机器人、人工智能是智能制造 “三驾马车”

丁汉院士演讲1月10日&#xff0c;由中国机电一体化技术应用协会、北京理工大学智能机器人与系统高精尖创新中心、中关村智友天使学院、机器人大讲堂(立德共创服务平台)、中关村融智特种机器人产业联盟和中关村信息谷等单位共同举办的2019年中国机器人行业年会在北京召开。会上&…

图像拼接---图片柱面投影简单实现

算法思想参考&#xff1a;http://blog.csdn.net/weixinhum/article/details/50611750 柱面投影是图片拼接的前期的一部分工作&#xff0c;以下代码只是简单的实现了投影&#xff0c;还可以优化&#xff0c; 柱面半径设置位图片宽度的一半&#xff0c;即 R width/2 代码运算…

photoshop问题

1、路径与形状有什么区别&#xff1f; 2、矢量蒙板作用及生成&#xff1f; 形状工具 U 可以生成 3、路径和形状的区别&#xff1f; 路径 矢量选区&#xff0c;半成品可转为蒙板&#xff0c;形状转载于:https://www.cnblogs.com/anjsxz/p/3963400.html

从消费端到企业端,从设备到数据:物联网市场的爆发式增长

来源&#xff1a;资本家实验室随着越来越多的设备接入网络&#xff0c;并实现相互沟通&#xff0c;我们正在加速进入“万物互联”的时代。在此背景下&#xff0c;连接设备的数量、产生的收入和数据量也将呈现惊人的增长&#xff1a;到2020年&#xff0c;全球连接设备数量将达到…

《LoadRunner 没有告诉你的》之四——理解性能

本文是《LoadRunner没有告诉你的》系列文章的第四篇&#xff0c;在这篇短文中&#xff0c;我将尽可能用简洁清晰的文字写下我对“性能”的看法&#xff0c;并澄清几个容易混淆的概念&#xff0c;帮助大家更好的理解“性能”的含义。 如何评价性能的优劣: 用户视角 vs. 系统视角…

容斥原理---概念介绍

容斥原理---概念介绍 容斥原理是一种基本的计数工具。 假设我们有N个对象的集合A&#xff0c;设a1, a2,…, ar是这些对象可能有的性质的集合&#xff0c;设N(ai )是有性质ai的对象数目。一个对象可能有若干个所讨论的性质&#xff08;或一个性质也没有&#xff09;。设N(a’i …

c#自动更新+安装程序的制作

一、自动更新的实现 让客户端实现自动更新&#xff0c;通常做法是在客户端部署一个单独的自动更新程序。主程序启动后&#xff0c;访问服务端&#xff0c;检查配置文件是否有更新版本&#xff0c;有更新版本就启动更新程序&#xff0c;由更新负责下载更新版本&#xff0c;并更新…

中国AI科研产出全球第一 但引文影响力低

来源&#xff1a;科学网 日前&#xff0c;爱思唯尔发布了《人工智能&#xff1a;知识的创造、转移与应用》报告&#xff0c;分析了全球人工智能科研的发展趋势。报告显示&#xff0c;2017年中国在人工智能领域出版的文章数量位列全球第一&#xff0c;科研产出已在2004年超过美国…

OpenCV--SIFT算法检测特征点

代码选自&#xff1a;http://blog.csdn.net/zhaocj/article/details/42124473 SIFT算法是用来检测图像中特征点的&#xff0c; 代码如下&#xff1a; opencv版本:2.4.9 #include "opencv2/opencv.hpp" #include "opencv2/imgproc/imgproc.hpp" #include…

对话 Geoffrey Hinton Demis Hassabis :人工智能离我们有多远?

来源&#xff1a;AI科技评论预测用户喜欢的音乐类型、检测出转移性肿瘤、生成脑癌的综合扫描、利用真实世界中拍摄的视频创造出虚拟环境、识别出被拐卖的人口、击败国际象棋大师以及专业的 Dota2 电竞团队、帮助 Alphabet 旗下的 Waymo 首次推出商业无人驾驶出租车服务、代替出…

SharePoint 2013 关于自定义显示列表表单的bug

1、在SharePoint 2013中&#xff0c;我们隐藏列表Dispform页面的ListFormWebPart部件&#xff0c;转而使用自定义显示列表表单进行展示&#xff0c;因为这样更容易定制我们需要的显示&#xff1b; 2、之后发现文件夹下的文档&#xff0c;查看属性会报错&#xff0c;如下图&…