[PTA] 习题4-3 求分数序列前N项和

本题要求编写程序,计算序列 2/1+3/2+5/3+8/5+... 的前N项之和。注意该序列从第2项起,每一项的分子是前一项分子与分母的和,分母是前一项的分子。

输入格式:

输入在一行中给出一个正整数N。

输出格式:

在一行中输出部分和的值,精确到小数点后两位。题目保证计算结果不超过双精度范围。

输入样例:

20
结尾无空行

输出样例:

32.66
结尾无空行

代码: 

#include <stdio.h>

int main(int argc, char *argv[]) 
{
	double N;
	int i;
	double j = 2,k = 1,copy;
	double sum = 0;
	scanf("%lf",&N);
	for (i = 0; i < N; i++) 
	{
		sum += 1.0*j/k;
		copy = j;
		j += k;
		k = copy;
	}
	printf("%.2lf",sum);
}

思路:

按照题目给的 “从第二项起,每一项的分子是前一项分子与分母的和,分母是前一项的分子” 提示,直接对应写出相关代码即可。

但是要注意,分子和分母可能会发生覆盖,因此要定义一个变量来保存其中一个,我保存的是分母。

还有就是,这里有一个小陷阱,当N是较大的时候,分子和分母可能出现值溢出,故使用double来定义分子和分母。(到这里,已经有好几道题出现这个问题了,不妨以后遇到计算类的题目,分子和分母不妨都定义为double,省的值总是越界(—__—!))。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值