题目链接

题意

甲、乙两人同时从A地出发要尽快同时赶到B地。出发时A地有一辆小车,可是这辆小车除了驾驶员外只能带一人。已知甲、乙两人的步行速度一样,且小于车的速度。问:怎样利用小车才能使两人尽快同时到达。

输入输出格式

输入格式:

仅一行,三个数据分别表示AB两地的距离s,人的步行速度a,车的速度b。

输出格式:

两人同时到达B地需要的最短时间,保留6位小数。

输入输出样例

输入样例#1:

120 5 25

输出样例#1:

9.600000

思路

小学奥数题。

|---s1--|--s2--|---s3--|
---------------········ 甲
---------------
|
-------- 车
|
---------------
········--------------- 乙

显然,要保证甲的步行时间与乙的步行时间相等,所以甲乙的行程是对称的,即\(s_1=s_3\)。又要保证总时间最短,所以小车应该在半路回头去接乙而不是原地不动等乙来。由此,可绘出上图。

由图可得知,甲步行到终点的时间 和 车回头接乙再带乙到终点的时间 相等。就样例而言,车速是步行速度的\(5\)倍,故车走的路程是人走的路程的\(5\)倍,车比人多走了\(4\)倍。又车与人共同行走了\(s_3\)的路程,所以车比人多走的是\(2*s_2\),是人走的\(4\)倍,故\(s_2=2*s_3\). 故\(s_2\)是两份,\(s_1\)与\(s_3\)都是一份。

而总时间可以直接看车走的路程,是整条路的长度加上折回来又折回去的路程,即\((1+2+1)+2*2=8\)份。

全部换成字母的话即为$$s+\frac{s}{\frac{\frac{v2}{v1}-1}{2}+2}*(\frac{v2}{v1}-1)$$

时间复杂度\(O(1)\).

Code

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
int main() {
double s, v1, v2;
scanf("%lf%lf%lf", &s, &v1, &v2);
printf("%.6f\n", (s + s * (v2/v1 - 1) / (v2 / (2*v1) + 1.5)) / v2);
return 0;
}

最新文章

  1. makefile之VPATH和vpath的使用
  2. sql server 触发器应用 insert
  3. druid 数据源 使用属性文件的一个坑
  4. oracle TIMESTAMP日期相减
  5. [APAC]查找资产表
  6. C++之路进阶——codevs2460(树的统计)
  7. HDU 1828 扫描线(矩形周长并)
  8. JQ获取当前是第几个元素,以及直接选取第几个元素的方法
  9. MVC EF ObjectStateManager 中已存在具有同一键的对象。ObjectStateManager 无法跟踪具有相同键的多个对象。
  10. web框架--来自维基百科
  11. richTextBox插入表格 完整版
  12. 实现自己的cp命令
  13. 一个i++和++i导致的严重的错误
  14. 一步一步重写 CodeIgniter 框架 (11) —— 使用 CodeIgniter 函数库
  15. .net图片裁剪抠图之性能优化
  16. webupload-upload执行上传时,进入的路径与linux服务器上的不一致
  17. linux 查看磁盘、文件夹、文件大小(df du)
  18. spring mvc跨域(post)--filter方案
  19. Windows &amp; RabbitMQ:安装
  20. AtCoder Beginner Contest 120 D - Decayed Bridges(并查集)

热门文章

  1. TP5 发送邮件代码
  2. composer 类加载器,对 &lt;PSR-4的风格&gt;、&lt;PSR-0的风格&gt;、&lt;PEAR的风格&gt; 风格的类的加载
  3. php使用curl获取文本出现中文乱码的解决办法
  4. 虚拟主机的搭建(ubuntu+apache2)
  5. JZOJ 5197. 【NOIP2017提高组模拟7.3】C
  6. 学习pytho第l六天 常用字符串用法
  7. 记忆化搜索:POJ1088-滑雪(经典的记忆化搜索)
  8. fetch 使用记录
  9. [状态更新]MSE三个月快速复习计划,成功考上复旦软工
  10. docker exec小脚本