求分数序列:2/1 + 3/2 + 5/3 + 8/5 +.....的前20项之和。
程序员文章站
2022-06-02 20:25:53
...
上代码之前先说一个要注意的点:整型 / 整型 = 整型,浮点型 / 浮点型 = 浮点型。
虽然分数序列中分子分母均为整型,但是两个整数相除可能为小数,在代码 sum += numerator / denominator; 这一句,如果我们定义分子分母为整型,那么结果仍为整型,例如分子为3,分母为2时,加入sum的是1而不是1.5,求和结果有误。所以我们把分子分母定义为浮点型,保证不会丢失数据。
#include<stdio.h>
void main()
{
int i;
double temp,sum = 0,numerator = 2,denominator = 1;
for(i = 0;i < 20;++i)
{
sum += numerator / denominator;
temp = numerator;
numerator = numerator + denominator;
denominator = temp;
}
printf("sum = %lf\n",sum);
}
结果如下图:
上一篇: 迷瘴 HDU - 2570 (精度,简单排序贪心)
下一篇: Mysql Error Code: 1175. You are using safe update mode and y_MySQL
推荐阅读
-
C#用递归算法实现:一列数的规则如下: 1、1、2、3、5、8、13、21、34,求第30位数是多少
-
js正则表达式之$1$2$3$4$5$6$7$8$9属性,返回子匹配的结果
-
C语言:有一个分数序列,2/1+3/2+5/3+8/5+13/8+…求出这个数列前 20 项的和
-
有一个分数序列 2/1+3/2+5/3+8/5+13/8+… 求出这个数列前 20 项的和。
-
编写计算并输出一个3*3阶矩阵对角线元素的和。 程序运行结果示例: 请输入数组元素:(3*3)↙ 1 2 3 4 5 6 7 8 9↙ ↙ 数组为:cqupt
-
给出数组array(1,9,5,8,3,7,2,4,6),写一个方法对其进行排序,使排序后的结果为(1,2,3,4,5,6,7,8,9)
-
1,2,3,4,5,6,7,8,9共9个数组成3个分数
-
设计静态方法模拟一对骰子。也就是说,随机出现一对 1, 2, 3, 4, 5, 6 之间的一个数。要求显示第一个骰子上的数,再显示第二个骰子上的数,最后输出显示两个数之和。
-
判断元素出栈、入栈顺序的合法性。如:入栈的序列(1,2,3,4,5),出栈序列为(4,5,3,2,1)是合法序列
-
[算法题(二)]已知一个数组(升序且不重复,如 1, 2, 3, 5, 7, 8, 9),要求输出:1 ~ 3、5,7 ~ 9。 即:连续的区间之间不输出中间的数字。