zoukankan      html  css  js  c++  java
  • 习题2.7 弹球距离 (15分)

    设有一个球从高度为h米的地方落下,碰到地面后又弹到高度为原来p倍的位置,然后又落下,再弹起,再落下…。请编写函数求初始高度为h的球下落后到基本停下来(高度小于给定阈值TOL)时在空中所经过的路程总和。

    函数接口定义:

    double dist( double h, double p );
    
     

    其中h是球的初始高度,p是球弹起高度与弹起前落下高度的比值;函数dist要返回球下落后到基本停下来时在空中所经过的路程总和。注意:当弹起的高度小于裁判程序定义的常数TOL时,弹起的距离不计算在内。

    裁判测试程序样例:

    #include <stdio.h>
    #define TOL 1E-2
    
    double dist( double h, double p );
    
    int main()
    {
        double h, p, d;
        scanf("%lf %lf", &h, &p);
        d = dist(h, p);
        printf("%.6f
    ", d);
        return 0;
    }
    
    /* 你的代码将被嵌在这里 */
    
     

    输入样例:

    1.0 0.4
    
     

    输出样例:

    2.319680


    double dist( double h, double p )//右一个注意点两次触地时走过的距离为 h+2*h*p
    {
        double mix=h*p;
        double sum = h;//第一次落下走过的距离是h
        while(mix>=TOL)
        {
            sum+= 2*mix;//第二次落下走过的是 h+2*h*p,依次类推
            mix = mix*p;
        }
        return sum;
    }
  • 相关阅读:
    转:Windows Socket五种I/O模型
    C++线程池的实现(二)
    C++ 简单 Hash容器的实现
    C++ TrieTree(字典树)容器的实现
    转载:C++线程池的一个实现
    C++用数组实现的静态队列
    C++ 类成员函数作为参数
    C++位操作符总结
    C++简单单例模式
    C++控制程序只运行一个实例
  • 原文地址:https://www.cnblogs.com/qinmin/p/12459026.html
Copyright © 2011-2022 走看看