C语言经典算法100例-020-小球自由下落问题

我们来看题:

一球从100 米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10 次落地时,共经过多少米?第10 次反弹多高?

1。分析,假设s代表路程,h代表弹起的高度,那么我们先做出数学模型:

s1=100;

h1=s1/2;

先看s2和s3的值如何求

s2=s1+2*h1;

s3=s2+2*h2; 其中h2=h1/2,所以有s10=s9+2*h9。按照这个思路,我们来写程序:

2.代码:

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int i;
    double sn=100;
    double hn=sn/2;
    for(i=2;i<=10;i++)
    {
        sn+=2*hn;
        hn/=2;
    }
    printf("Total %lf\n",sn);
    printf("h10 is %lf\n",hn);
    return 0;
}

这里我们只循环了9次,因为s1和h1先求出来了。因此循环中是从 s2开始算的,最终10次后的结果就是s10,而此后hn又自除了2,所以hn就是h10。

多琢磨几遍就懂了。

结果如下:

Total 299.609375
h10 is 0.097656

posted @ 2014-03-03 17:36  庄浩  阅读(2214)  评论(0编辑  收藏  举报