UESTC 169 快快告诉我时间

135 篇文章 0 订阅
44 篇文章 0 订阅

你知道吗,小明的舅舅是有名的科学家!小明经常在电视上看到舅舅被一大群拿着黑色短棍子的人围着,妈妈说,那是记者们在采访舅舅。小明生日这天舅舅虽然没有来,可是却送来了一个很神秘的礼物。

咦,一个哑铃状的装着红色沙子的玻璃管子固定在木头架子上,这是什么东西呢?妈妈说,这个东西叫“沙漏”,是很久很久以前人们用来算时间用的。可是妈妈却没有说人们是怎么用它来算时间的。于是小明开始了研究。

.*

小明发现沙漏玻璃管的两端很大,而中间却很小。把沙漏竖着立起来的时候,上面的沙子会顺着中间的小洞“流”到下面去。小明猜想,上面的沙子流下来是需要时间的,那么很久很久以前的人们肯定就是数下面的沙子然后算出时间了的,可是小明怎么也找不到这个玻璃管子的开口处,所以没办法来数沙子,那到底该怎么算时间呢?

小明想到了去年舅舅送了他的那根尺子,当时舅舅还教了小明怎么用它来量东西呢!小明把沙漏底部的沙子摇平了,然后测出了沙子的高度。小明觉得这个高度应该就可以用来算出时间了,可是他不会算,请问你会吗?

假设小明可以把沙漏下部的沙子完全摇平,即沙子构成一个上下底面平行的锥台。另外,假设小明能准确测量出平台的高度即平台上下底面的距离。

.*

假设小明的沙漏是由两个高度为H,底面半径为R的圆锥体玻璃管竖直对接而成,即两锥体的底平面平行且顶点重合。同时,假设任何时候沙子从沙漏上部到达下部的用时相同,设单位体积(1立方毫米)的沙子下落所需要的时间为0.20s

Input

输入的第一行是T(不超过3000)。T表示测试部分的个数,每一部分都要求单独计算并按照要求输出结果。接下来是每一行为一个测试部分。每一行为H,R,h,分别表示沙漏圆锥体的高度H以及底面半径R,小明测得的沙漏下部沙子锥台的高度的hHR为整数,h都是浮点数且h\leq HHRh的单位都为毫米。

Output

对于每个测试部分,请以s为单位输出构成小明所测的沙子平台所需要的时间,小数点后保留两位。为避免不必要的错误,请尽量使用double。请使用正确的方法以减小浮点运算中出现的精度误差。

Sample Input

5
50 50 0.000000
50 50 1.000000
50 50 25.000000
50 50 30.000000
50 50 50.000000

Sample Output

0.00
1539.59
22907.45
24504.42
26179.94



#include <stdio.h>

int main()
{
    double pai=3.14159265358979;
    double h,v1,v2,r;
    int cas,H,R;
    scanf("%d",&cas);
    while(cas--)
    {
        scanf("%d %d %lf",&H,&R,&h);
        r=R*(H-h)/H;
        v1=pai*R*R*H/3;
        v2=pai*r*r*(H-h)/3;
        printf("%.2lf\n",(v1-v2)*0.2);
    }
    return 0;
}



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值