给出递归算法的一个例子
递归算法是一种算法思想,主要解决已知序列初始部分的值f(0)~f(k),以及f(n+1)与f(n)~f(m)之间关系,求解f(x)的问题。
其中m-n 小于等于k 。
例如斐波纳契数列问题
已知 f(0) = 0,f(1) = 1, f(n + 1) = f(n - 1) + f(n - 2) (n>=2,n∈N*)
此时可得递归思想书写的算法函数
int f(unsigned int k)
{
if (k == 0)
return 0;
else if (k == 1)
return 1;
else
return f(k - 1) + f(k - 2);
}C语言如何用递归算法求1!+2!+3!+...n!
#include<stdio.h>
float fun(int n)
{
if(n==1) return 1;//如果n=1则直接返回1
return n*fun(n-1);//否则返回n*fun(n-1),以此计算n的阶乘,这条语句就是递归体
}
void main()
{
int i;
float sum=0;
for(i=1;i<=n;i++){
sum+=fun(i); //循环调用,用sum累计
}
printf("sum=%.2f
",sum);
}递归算法的是怎么回事?
和迭代差不多,只是通过定义和调用函数来实现迭代
把事情分解成相同的步骤重复执行直到符合某一条件时结束,再反过来递推到最初的状态,问题就解决了
比如定义(用的是C语言)
int fun(int a)
{
if(a==1) return 1;
else
{
a=a*fun(a-1);
return a;
}
}
在fun里面再定义fun,这个fun都只做一件事,把a的内容和fun(a-1)相乘作为返回值
这里要有个终止条件,即a=1时返回值为1,这样,如果我给最初的fun里的a赋值为5,第一步为5*fun(4),而执行fun(4)的结果为4*fun(3)....直到fun(2)=2*fun(1)即fun(2)=2*1,再把fun(2)代回去,得fun(3)=3*2*1,最后倒推的结果为fun(5)=5*4*3*2*1,即这个递归函数实现了a的阶乘fun(a)=a!
够详细了吧,觉得好的话给我加分吧 ^_^递归算法的例子
c语言中递归的最经典应用是求两个数的最小公约数,代码如下:
int MinDivisor( int m, int n)
{
if(m%n==0)
return n;
else
return MinDivisor(n, m%n);
}c语言递归法
/*先输入n再输入r;
n不要超过30
程序列出所有组合情况,并且计数
样例输入:
4 3
样例输出:
1 2 3
2 2 4
3 3 4
4 3 4
*/
#include<stdio.h>
#define MAXN 31
int res[MAXN];
int N,M,count;
void outres()
{
int i;
count++;
printf("%d",count,res[1]);
for (i=2; i<=M; i++)
printf(" %d",res[i]);
printf("
");
}
bination(int no)
{
int i,k;
if (no>M)
outres();
else
{
k=res[no-1]+1;
for (i=k; i<=N-M+no; i++)
{
res[no]=i;
bination(no+1);
}
}
}
int main()
{
scanf("%d%d",&N,&M);
count = 0;
res[0]=0;
bination(1);
return 0;
}
今天下午遇到一个网友聊到他昨天新注册的一个域名,今天在去使用的时候发现域名居然不见。开始怀疑他昨天是否付款扣费,以及是否有实名认证过,毕竟我们在国内域名注册平台注册域名是需要实名认证的,大概3-5天内如果不验证那是不可以使用的。但是如果注册完毕的域名找不到那也是奇怪。同时我也有怀疑他是不是忘记记错账户。毕竟我们有很多朋友在某个商家注册很多账户,有时候自己都忘记是用哪个账户的。但是我们去找账户也不办...
这两天在站长群里看到不少有使用DEDECMS织梦程序的朋友比较着急,因为前两天有看到来自DEDECMS,我们熟悉的织梦程序官方发布的公告,将会在10月25日开始全面商业用途的使用DEDECMS内容管理程序的会采用授权收费模式,如果我们有在个人或者企业商业用途的,需要联系且得到授权才可以使用,否则后面会通过维权的方式。对于这个事情,我们可能有些站长经历过,比如字体、图片的版权。以及有一些国内的CMS...
快云科技: 11.11钜惠 美国云机2H5G年付148仅有40台,云服务器全场7折,香港云服务器年付388仅不到五折 公司介绍:快云科技是成立于2020年的新进主机商,持有IDC/ICP/ISP等证件资质齐全主营产品有:香港弹性云服务器,美国vps和日本vps,香港物理机,国内高防物理机以及美国日本高防物理机官网地址:www.345idc.com活动截止日期为2021年11月13日此次促销活动提供...
递归法为你推荐
drainage排水承泄区指什么?excel通配符Excel 条件中带有通配符的怎么用sumif微信红包图片怎么发微信要红包图片wrangleGXG,CK,wrangle,replay哪个牌子档次高?scanf返回值何为函数的返回值,比如scanf()函数的返回值?电视蚂蚁电视蚂蚁是不是不能用了?我在国外该怎样看奥运?安卓模拟器哪个好用安卓模拟器哪个好用高质量图片iphone上有什么高质量的壁纸APP吗色温图色温,色调等参数怎么改?(图),还有什么建议吗?小蓝条戴尔系统开机动画里的小蓝条怎么去
x3220 80vps cdn服务器 我爱水煮鱼 架设服务器 有奖调查 韩国名字大全 东莞服务器 七夕快乐英语 游戏服务器出租 中国linux 谷歌台湾 腾讯网盘 宿迁服务器 带宽测试 杭州电信宽带 乐视会员免费领取 谷歌搜索打不开 百度新闻源申请 机柜尺寸 更多