| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 6990 人关注过本帖
标题:递归算法:找出n个自然数取r个数的组合,求解释,详细点
只看楼主 加入收藏
风雨123
Rank: 2
等 级:论坛游民
帖 子:84
专家分:65
注 册:2013-2-23
结帖率:66.67%
收藏
已结贴  问题点数:10 回复次数:5 
递归算法:找出n个自然数取r个数的组合,求解释,详细点
当n=5 r=3;
5  4   3
5  4   2
5   4   1
 5  3  2
5  3  1
5   2    1
4    3  2
4      3    1
4    2    1
3   2    1
程序代码:
//这个是一般的方法
#include <iostream>
using namespace std;
int main()
{
int n=5,i,j,k,t;
t=0;
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
for(k=1'k<=n;k++)
if(i<j && j<k)
{
   t++;
cout<<i<<" "<<j<<" "<<k<<endl;
}
cout<<t<<endl;
return 0;
}





另一种方法:


//递归
comb(int m,int k)
{
  int i,j;
for(i=m;i>=k;i--)
{
  a[k]=i;
  if(k>1)
comb(i-1,k-1);
else
{
  for(j=a[0];j>0;j--)
cout<<a[j]<<" ";
cout<<endl;

}
}
}
int main()
{
  int n,r;
cin>>n>>r;
if(r>n)
cout<<"error"<<endl;
else
{
   a[0]=r;
  comb(n,r);
}
}



[ 本帖最后由 风雨123 于 2013-8-4 17:08 编辑 ]
搜索更多相关主题的帖子: color 自然数 include 
2013-08-04 17:06
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
收藏
得分:0 
为什么我感觉下面的代码是错的。

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-08-04 18:48
风雨123
Rank: 2
等 级:论坛游民
帖 子:84
专家分:65
注 册:2013-2-23
收藏
得分:0 
加上头文件#include <iostream>
          using namespace std;
运行是对的。求解释。
2013-08-05 06:34
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2392
专家分:13384
注 册:2013-3-3
收藏
得分:0 
我觉得可以比较下二者哪个更好,时间复杂度和空间复杂度比较下

Maybe
2013-08-05 07:54
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
收藏
得分:10 
我的分析:(没上编译器调试哈,懒得拷代码)
  if(k>1)
comb(i-1,k-1);
这个保证了k最小是1

  for(j=a[0];j>0;j--)
cout<<a[j]<<" ";
cout<<endl;
这个明显是在打印结果

a[0]=r;
那就是说除了这里,第0个元素没地方赋值啊
那么,打印的结果必定包含r
但是结果明显不是啊...

我是不是看漏了什么?

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-08-05 08:15
小小伞
Rank: 2
等 级:论坛游民
威 望:1
帖 子:8
专家分:10
注 册:2016-3-16
收藏
得分:0 
2017-05-13 10:14
快速回复:递归算法:找出n个自然数取r个数的组合,求解释,详细点
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015716 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved