子集生成-创新互联
用二进制位的0和1表示集合中是否存在该元素
站在用户的角度思考问题,与客户深入沟通,找到福建网站设计与福建网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:成都网站设计、成都网站建设、企业官网、英文网站、手机端网站、网站推广、域名注册、网页空间、企业邮箱。业务覆盖福建地区。
要生成0~n的子集,先生成0~n的二进制序列,这些序列的0、1位正好可以对应一个子集中全集在该位置上的元素是否存在,将其作为子集中存在的元素的标记,输出对应元素。#include
#include
#include
#includeusing namespace std;
void subset(int n,int s){
for(int i=0;iif(s&(1<//s&(1<}
printf("\n");
}
int main(){
int n=4;
for(int i=0;i<(1<//i<(1< subset(n,i);
}
#include
#include
using namespace std;
void print_subset_zl(int n,int* A,int cur){//增量构造法
for(int i=0;i
int s=cur?A[cur-1]+1:0;//定序,确保只输出一次相同的集合
for(int i=s;i
print_subset_zl(n,A,cur+1);
}
}
void print_subset_wxl(int n,int* B,int cur){//传递数组
if(cur==n){
for(int i=0;i
return;
}
B[cur]=1;//选
print_subset_wxl(n,B,cur+1);
B[cur]=0;//不选
print_subset_wxl(n,B,cur+1);
}
void print_subset_binary(int n,int s){
for(int i=0;i
}
int main(){
int k[5];
print_subset_zl(5,k,0);
print_subset_wxl(5,k,0);
for(int i=0;i<(1<<5);i++){
print_subset_binary(5,i);
}
return 0;
}
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
本文题目:子集生成-创新互联
新闻来源:http://cdiso.cn/article/ghjgc.html