试编写一个递归函数,用来输出n 个元素的所有子集。

执假以为真 2008-09-04 11:32:29
试编写一个递归函数,用来输出n 个元素的所有子集。
例如,三个元素{a, b, c} 的所有子集是:
{ }(空集),{a}, {b}, {c}, {a, b}, {a, c}, {b, c} 和{a, b, c}。
...全文
302 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
jieao111 2008-09-05
  • 打赏
  • 举报
回复
这个问题正统的做法确实是递归,不过我这有个好的方法,效率高些。
int main()
{

int arry[]={1,2,3,4,5,8},num=0;
int n=sizeof(arry)/sizeof(int);
bitset<32>x;
for(int i=0;i<1<<n;++i)
{
x=i;
num=0;
for(int j=0;j<n;++j)
if(x[j])
cout<<arry[j];
cout<<endl;

}

}
太乙 2008-09-05
  • 打赏
  • 举报
回复
汗~~数据结构、算法那本书上的练习题吧?

当时我写这个程序可写了好长一段时间咯!

递归挺好!
执假以为真 2008-09-05
  • 打赏
  • 举报
回复
贾诩的也不错,我稍后好好看看。
执假以为真 2008-09-05
  • 打赏
  • 举报
回复
Jieao111的方法确实不错,我会给分的。
今天比较忙,看算法需要时间,一周之内把5个帖子都结了。有好的递归的再往上写啊。
谢谢,再会。
lin_style 2008-09-04
  • 打赏
  • 举报
回复
void permute(int permlist[], int start, int n)
{
int tmparr[UpperLimit];
int temp, i;

if(start ==n-1)
{
for(i = 0; i<n; i++)
{
cout<<permlist[i]<<" ";
}
cout<<endl;
}
else
for( i=start; i<n; i++ )
{
temp = permlist[i];
permlist[i] = permlist[start];
permlist[start] = temp;

copy(tmparr, permlist, n);
permute(tmparr, start+1, n);
}

}


npuhuxl 2008-09-04
  • 打赏
  • 举报
回复
void f(bool in[N], int m)
{
if(m == N)
{
cout<<"{";
for(int i = 0; i < N; ++ i) if(in[i]) cout<<(char)('a'+i)<<",";
cout<<"}"<<endl;
return ;
}
in [m] = true;
f(in, m+1);
in[m] = false;
f(in, m+1);
}
//大致是这样吧!不知道有没有错
lin_style 2008-09-04
  • 打赏
  • 举报
回复
怎么有五个帖子??

我看错了??

64,636

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧