社区
C++ 语言
帖子详情
关于求子集 用递归算法
dicky_yz
2007-04-30 11:51:11
输入任意元素 能得出它的所有子集。
如输入:a 2 zf 得到:{},{a},{2},{zf}{a,2},{a,zf},{2,zf},{a,2,zf}
希望高手们多多指教,小弟感激不尽。
...全文
1148
4
打赏
收藏
关于求子集 用递归算法
输入任意元素 能得出它的所有子集。 如输入:a 2 zf 得到:{},{a},{2},{zf}{a,2},{a,zf},{2,zf},{a,2,zf} 希望高手们多多指教,小弟感激不尽。
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
4 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
laiwusheng
2007-05-01
打赏
举报
回复
#include <string.h>
#include <iostream>
using namespace std;
void build(char str[],int n)
{
if(n==0)//控制输出
{
cout< cout< }
else
{
build(str,n-1);
char newstr[5] = {' '};//去掉就把该位置的元素置成空
strcpy(newstr,str);
newstr[n-1]=' ';
build(newstr,n-1);
}
}
void main()
{
char string[5]="abc";//实例集合放在数组中
build(string,3);
}
medie2005
2007-05-01
打赏
举报
回复
楼主自己先将整个搜索过程表示为搜索树的形式,问题自然就很简单了。
每一个元素对于一个子集来说,只有两中状态:0表示不属于该子集,1表示属于该子集。程序中的数组a就是采用这种表示。因此,搜索过程表示为树的形式就是这样的:
a
0/ \1
b c
0/ \1 0/ \1
...........
因此:
代码中的第一个“trail(t,i+1,n);”就是搜索当前扩展节点的左子树(因为a[i]此时的值为0)。
代码中的“a[i]=1-a[i];”就是变换当前扩展节点的状态,也就是从左子树换到右子树。
代码中的第二个“trail(t,i+1,n);”就是搜索当前扩展节点的右子树。
dicky_yz
2007-05-01
打赏
举报
回复
等待ing。。。。。。
dicky_yz
2007-05-01
打赏
举报
回复
#include<iostream.h>
void trail(char *t, int i, int n);
int a[6] = {0};
void main()
{
cout<<"请输入元素:"<<endl;
char b[6];
cin>>b;
cout<<"它的子集有:"<<endl;
trail(b,0,sizeof(b));
}
void trail(char*t,int i,int n)
{
int j;
if(i < n)
{
trail(t,i+1,n);
a[i]=1-a[i];
trail(t,i+1,n);
} //这个递归块是什么意思啊?
else
{
cout<<"{";
for(j=0; j<=n;j++)
{
if(a[j])
cout<<t[j]<<", ";
}
cout<<"}"<<endl;
}
}
在别的地方弄得的代码,可还是有些地方不懂,主要是递归的那里。高手能详细解释下吗?
用回溯法
求
子集
和的c++代码
一个程序,很好的。是关于如何用回溯法
求
子集
和的。
信息学竞赛宝典-基础算法视频讲解-第3章 枚举算法
信息学竞赛宝典--基础算法》,人民邮电出版社 c++基础算法视频讲解---第3章 ...第02章
递归算法
第03章 枚举算法 第04章 递推算法 第05章 分治算法 第06章 贪心算法 第07章 排序算法 第08章 高精度算法 第09章 搜索算法
回溯法
求
解
子集
和问题
用回溯法实现
子集
和问题的完整代码
1.4
求
集合的所有
子集
问题.rar
求
集合的所有
子集
问题,提供的全部代码。 使用
递归算法
!
基于Python数据结构之递归与回溯搜索
能采用递归描述的算法通常有这样的特征:为
求
解规模为N的问题,设法将它分解成规模较小的问题,然后从这些小问题的解方便地构造出大问题的解,并且这些规模较小的问题也能采用同样的分解和综合方法,分解成
C++ 语言
64,646
社区成员
250,476
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下
试试用AI创作助手写篇文章吧
+ 用AI写文章