| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1346 人关注过本帖
标题:题目是:2/1 3/2 5/3 8/5 ……求前30个和 有些地方不懂
只看楼主 加入收藏
甜甜的惟
Rank: 2
等 级:论坛游民
帖 子:66
专家分:19
注 册:2016-11-26
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:7 
题目是:2/1 3/2 5/3 8/5 ……求前30个和 有些地方不懂
题目是:2/1 3/2 5/3 8/5  ……求前30个和

#include<stdio.h>
 #include<math.h>
 float fun(int n,float x,float y)
 {
     float s=0;
     if (n!=30)
         s=fun(n+1,x+y,x);
      return (s+x/y);
 }
 int main()
 {
     printf("%f\n",fun(1,2,1));
     return 0;
 }

 s=fun(n+1,x+y,x);
      return (s+x/y);这个地方我不懂,另外还想问一下fun(1,2,1)是怎么取上值的


搜索更多相关主题的帖子: include return 
2016-11-29 20:34
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:10 
第一个参数是累加的元素个数,第二个参数是当前这一项的分子,第三个参数是分母
s=fun(n+1,x+y,x);计算的是从第n+1项开始到第30项的和,return (s+x/y);是把第n项加上去再返回给调用单位。
2016-11-29 20:44
LG隐
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:67
专家分:198
注 册:2016-4-20
收藏
得分:2 
fun(1,2,1)中第一个‘1’是计数的,你不是要求前三十个嘛,这个数你可以随便给啊,比如给2,fun()函数里的判断就改为if(n!=31),保证进行30次就行了。
2016-11-29 20:45
甜甜的惟
Rank: 2
等 级:论坛游民
帖 子:66
专家分:19
注 册:2016-11-26
收藏
得分:0 
回复 2楼 yangfrancis
我想问的就是s=fun(n+1,x+y,x);是怎么得出s的值的,另外,他是怎么循环30次的,s=fun(n+1,x+y,x);为什么放在return ()前?
2016-11-29 20:57
LG隐
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:67
专家分:198
注 册:2016-4-20
收藏
得分:2 
1.2.3.5.8.13.21.34..这个是斐波那契数列,他的规律是任一个数的值等于它前两个数的和。每个分数的分子是前一个分数的分子分母之和,分母是前一个分数的分子。fun(1.2.1)中后面的‘2’,‘1’就像一楼说的代表分子分母(因为你第一项取得是2/1,如果是3/2,他就是3.2了)。所以递归调用时参数分子为x+y,分母为x.return(s+x/y),使s随时更新得到你想要的结果。
2016-11-29 21:15
LG隐
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:67
专家分:198
注 册:2016-4-20
收藏
得分:2 
这个是递归啊,函数内部调用自己,在函数中做一个计数器来控制调用自己的次数。
2016-11-29 21:17
LG隐
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:67
专家分:198
注 册:2016-4-20
收藏
得分:4 
程序很简洁,建议楼主把程序一步步走一遍,记录好每个变量如何变化。
2016-11-29 21:20
甜甜的惟
Rank: 2
等 级:论坛游民
帖 子:66
专家分:19
注 册:2016-11-26
收藏
得分:0 
回复 7楼 LG隐
谢谢
2016-11-29 21:33
快速回复:题目是:2/1 3/2 5/3 8/5 ……求前30个和 有些地方不懂
数据加载中...
 
   



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

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