解题思路:
这道题可以使用递归来求解,利用递归求解n次后弹出的高度很容易(下面的calculate直接可以得到),但是在求出反弹总路径量的时候,通过示例输入和输出发现最后一次弹出的高度不算,第一次的高度只算一次,中间的弹出和落下各一次也就是两次,所以引入了一个变量c记录上一次反弹的总高度,也就是这一次弹出和落下的总高度,最后一次不需要计算,所以递归的结束条件也就没有到b==0。
注意事项:
总路程量需要仔细观察示例的输入和输出
参考代码:
#include<stdio.h>
double sum(double a,double b,double c)
{//引入c的作用是为了这个问题中中间段的数需要*2
return b == 1?c:c+sum(a/2,--b,a);
}
double calculate(double a,double b)
{
return b == 0?a:calculate(a/2,--b);
}
int main()
{
double a,b;
scanf("%lf%lf",&a,&b);
printf("%.2lf %.2lf",calculate(a,b),sum(a,b,a));
return 0;
}
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题8.1 (C语言代码)浏览:517 |
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:853 |
1012题解浏览:861 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:504 |
大神老白 (C语言代码)浏览:600 |
交换Easy (C语言代码)浏览:759 |
C语言程序设计教程(第三版)课后习题8.2 (C语言代码)浏览:1028 |
神奇的fans (C语言代码)浏览:977 |
C语言程序设计教程(第三版)课后习题8.9 (C语言代码)浏览:498 |
C语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:473 |