C语言s=2/1+3/2+5/3+8/5+....前20项的和

1.#include<stdio.h>voidmain(){inta,c,n;floatt,sum,b;//注意这里的b和下面的b的位置sum=0;a=1;b=2;for... 1.#include<stdio.h>
void main()
{
int a,c,n;

float t,sum,b;//注意这里的b和下面的b的位置
sum=0;
a=1;
b=2;
for (n=1;n<21;n++)
{
t=b/a;
c=a+b;
sum=sum+t;
a=b;
b=c;
}
printf("%f\n",sum);
}

2.#include<stdio.h>
void main()
{
int a,b,c,n;//把b放在这里为什么不正确?为什么要把b放在float哪里?求解析!!!

float t,sum;
sum=0;
a=1;
b=2;
for (n=1;n<21;n++)
{
t=b/a;
c=a+b;
sum=sum+t;
a=b;
b=c;
}
printf("%f\n",sum);
}
展开
 我来答
靓丽还清湛的标兵5177
2011-12-27 · TA获得超过1649个赞
知道小有建树答主
回答量:1032
采纳率:100%
帮助的人:990万
展开全部
#include <stdio.h>
double theSum(int N)
{
int n;
double An_2,An_1,An;
double S;
S=0.0; An_2 = An_1 = 1.0; //初值 实形数
for(n=0; n<N; n++)
{
An=An_1+An_2; //数列下一项 分母
S += An_1/An; //累加
An_2=An_1; An_1=An; //叠代
}
return S;
}

void main()
{
int Nx;
printf("退出方法: 输入小于0的数 或用CTRL+C\n");
while(1)
{
printf("\n请输入累加的前N项数目:");
fflush(stdin); //清空键盘输入缓冲区
scanf("%d",&Nx); //输入项数
if(Nx<0) return; //小于0项则退出
printf("前%d项的和:%.15lf \n", Nx, theSum(Nx));
}
}
///////////前任意项的和,随你便。 完整调试版 /////////////////////////////////
////////////////////////////////////////////////附精简版本:////////////////////////////////////////
#include <stdio.h>
double theSum(int N)
{
int n;
double S,An_2, An_1, An;
S=0.0; An_2=An_1=1.0; //初值
for(n=0; n<N; n++)
{
An = An_1+An_2; //数列之分子分母的特点
S += An_1/An; //累加
An_2=An_1; An_1=An; //叠代
}
return S;
}
void main()
{
int n=20;
printf("前%d项的和为:%.15lf", n, theSum(n));
}
//////////////////////////精简版结束 这排版真是怪呀,前导空格一样多时还长短不一,晕
//初次没看清题,现已修正 还好有回头检查的习惯 如果确信不会把代码用于计算超过20项的话,选1楼的回答就足够 我这个是把问题复杂化了,可以应付前任意项的和
qicaiwuya
推荐于2018-02-28 · TA获得超过4213个赞
知道小有建树答主
回答量:1462
采纳率:100%
帮助的人:1220万
展开全部
举个例子你就明白了,3/2 看起来应该是1.5,但是实际结果是1,因为c语言在处理3/2的时候,由于3和2都是整数,所以进行的整除运算,即结果没有小数部分(是直接去掉,而不是四舍五入)。
但是如果写成3.0/2那么结果就是1.5了,原因就是3.0/2这个式子中有小数,所以进行的是小数运算,结果会保留小数部分。
你的第一个代码中b定义为float类型,所以b/a进行的是小数除法运算,而第二个代码中b定义为int类型,所以进行的是整除运算,结果自然不对。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cobrawlm
2014-03-22 · TA获得超过136个赞
知道答主
回答量:81
采纳率:0%
帮助的人:22.9万
展开全部
1.在计算机中:两个整型数相除,其结果还是整型(只保存整数部分);浮点数与整型数、浮点数与浮点数相除,结果为浮点数。

2.要想让两个整型数相除得到浮点数,至少要让其中一个整型数强制转换为浮点数。

3.所以,第一段代码能得到正确结果,第二段的结果是错的。

4. 第二段代码中,如果将for循环中的语句t=b/a;改成t=(float)b/a;,一样能得到正确结果,而且更符合题意。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
青楼国际
2011-12-27 · TA获得超过115个赞
知道答主
回答量:34
采纳率:0%
帮助的人:36.6万
展开全部
void main()
{
int i, j, k, n, t;
float sum;

i = 1;
j = 2;
sum = 0;

for (k = 1; k <=20; k++)
{
sum += (float)i/(float)j;
t = i + j;
i = j;
j = t;
}

printf("sum = %f\n", sum);

return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
zxh820217
2007-04-02 · TA获得超过176个赞
知道答主
回答量:53
采纳率:0%
帮助的人:76.2万
展开全部
#include<stdio.h>
main()
{
float numerator = 1, denominator = 2, temp;
float total = 0;
int num;
total += 1;//第一项
for( num=0; num<19; num++ )//后十九项
{
total += numerator / denominator;
temp = denominator;
denominator += numerator;
numerator = temp;
}
printf("total = %f\n",total);
}

VC编译通过,希望对你有点帮助。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(9)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式