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

page10 2005-05-20 10:33:48
试编写一个递归函数,用来输出n 个元素的所有子集。例如,三个元素{a, b, c} 的所有
子集是:{ }(空集),{a}, {b}, {c}, {a, b}, {a, c}, {b, c} 和{a, b, c}。
...全文
523 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
flyingdancing2005 2005-05-20
  • 打赏
  • 举报
回复
up
jpq1982 2005-05-20
  • 打赏
  • 举报
回复
想法就是, 对a, b, c进行排列组合,
然后对结果取前两个, 放入outter_set,
继续递归对前两个排列组合. 直到set里只有一个元素了.

最后再加一个a, b, c就可以了.
jpq1982 2005-05-20
  • 打赏
  • 举报
回复
set<int> inner_set;
set<set<int> > outter_set;

void find_set(set<set<int> >& ssi, const set<int>& input_set, int n)
{
if (n==1) {
ssi.insert(input_set);
} else {
while (next_permutation(input_set.begin(), input_set.end())) {
set<int>::const_iterator inner_end = input_set.begin();
advance(inner_end, n-1);
set<int> tmp(input_set.begin(), inner_end);
ssi.input(tmp);

find_set(ssi, input_set, n-1);
}
}
}

除了效率低了点, 没什么优点:)
Beover1984 2005-05-20
  • 打赏
  • 举报
回复
一种思路:空集,一个元素的集合,两个元素的集合,三个元素的集合.....

另一种思路:空集,所有和A构成的集合,所有和B构成的集合......

自己多想想吧,程序还是要靠自己写的
foochow 2005-05-20
  • 打赏
  • 举报
回复
论坛上搜索下....问过好多次了^_^

65,208

社区成员

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

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