鱼C论坛

 找回密码
 立即注册
查看: 2535|回复: 1

[技术交流] 002:棍的膨胀

[复制链接]
发表于 2018-2-4 17:22:01 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 Messj 于 2018-6-8 23:34 编辑

已知一根长为L的细棍被加热了n摄氏度,那么其新的长度为L'=(1+n*C)*L。中间的C是热膨胀系数。当一根细棍被夹在两面墙中间然后被加热,它会膨胀,其形状会变成一个弧,而原来的细棍(加热前的细棍)就是这个弧所对的弦。你的任务是计算出弧的中点与弦的中点的距离。

                               
登录/注册后可看大图


输入
包含多组数据(每组占一行)。每一行包含三个非负数:细棍的长度,温度的变化值和细棍材料的热膨胀系数C。输入数据保证细棍不会膨胀超过自己的一半。输入数据以三个连续的-1结尾。

输出
对于每一组数据,输出计算的距离,答案保留三位小数。

样例输入
1000 100 0.0001
15000 10 0.00006
10 0 0.001
-1 -1 -1

样例输出
61.329
225.020
0.000

本帖被以下淘专辑推荐:

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-2-4 17:43:58 | 显示全部楼层
解析:https://www.cnblogs.com/SinGuLaRiTy2001/p/7171242.html#_label0

之所以可以使用分治策略中的二分渐进法,是由于偏移的距离与角度成正比,有单调性。

  1. #include<cstdio>
  2. #include<cmath>

  3. using namespace std;
  4. #define eps 1e-4

  5. double l,ll,n,c,r,sita;//l-棍长 n-温度 c-膨胀常量 ll-弧长 r-半径 sita-对应角

  6. double solve(double a,double b) //二分渐进法
  7. {
  8.         double left,right,mid;
  9.         left=a;
  10.         right=b;
  11.         while(left+eps<right)
  12.         {
  13.                 mid=(left+right)/2;
  14.                 r = l*l/8/mid+mid/2;
  15.                 sita = 2*asin(l/2/r);
  16.                 if(sita*r>ll)  // ll=sita*r  l=sin(sita)*r
  17.                         right=mid;
  18.                 else
  19.                         left=mid;
  20.         }
  21.         return left;
  22. }
  23. int main()
  24. {
  25.         while(scanf("%lf%lf%lf",&l,&n,&c))
  26.         {
  27.                 if(l<0||n<0||c<0)break;
  28.                 ll=l*(1+n*c);
  29.                 printf("%.3f",solve(0,l/2));
  30.         }
  31. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-7 13:00

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表