Problem 1 珠江夜游 (cruise.cpp)

【题目描述】 小 Z 放假后难得来一趟广州游玩,当然要吃遍广州各路美食小吃然后再 到珠江新城看看远近闻名的小蛮腰啦!可当小 Z 一路吃吃吃以后,天渐渐黑了, 珠江边上的建筑全亮起了灯,好看得不要不要的,于是小 Z 决定搭乘游艇从西 边的广州港沿着珠江夜游到小蛮腰脚下。小 Z 的游艇一路向东,可小 Z 却感觉 船动得出奇的慢,一问船家才知道,原来今天珠江上堵船了。 我们可以把供游艇航行的航道看作一条单行道,航道上 N+1 艘游艇自西 向东依次编号为 0..N,小 Z 所在的游艇在最西边编号为 0,而编号为 N 的游艇 还要再往东航行一段才是小蛮腰。由于晚上航行视野不佳,排在后面的船不允 许超越前面的船,而当前面的船航行速度太慢时,后面的船只能以相同的速度 紧跟着,此时两船之间的距离可以忽略。 已知第 i 艘游艇船身长为 L[i],船头与小蛮腰距离为 X[i],最大航行速 度为 V[i]。小 Z 好奇,他到底要等多久,才能乘着游艇经过小蛮腰脚下呢? 【输入格式】

第一行为测试数据组数 T,表示接下来有 T 组数据。 每组测试数据第一行为一个正整数 N,表示排在小 Z 前面的游艇数量。 接下来 3 行,每行包含 N+1 个数字,每行的第 i 个数字分别为 L[i], X[i]和 V[i],含义见题面描述。

【输出格式】

每组测试数据输出一行,包含一个实数,表示小 Z 要等待的时间,至少 保留三位小数。 设你的输出答案和标准答案分别为 a 和 b,若 fabs(a-b)/max(1,b)<1e-3, 则认为你的输出答案是正确的。

【样例输入】

2

1

2 2

7 1

2 1

2

1 2 2

10 7 1

6 2 1

【样例输出】

3.500

5.000

第二种方法:

可以直接二分最终时间,然后从第一辆船开始递推求出每辆船的最终位置。 复杂度为 O(nlogC),也可以过。二分给定一个 mid,进行 check 的时候,我们只需要记录 下来前一辆船船头最终能到达的位置-前一辆船的长度的值,然后计算当前这辆船的船头 能到达的最远距离(在没有船挡路的情况下),然后在两者之间取一个 min 就是该船船头 能到达的最终位置。递推计算最远的船能否通过终点即可。(任何一辆船达不到终点即可 返回)

第三种方法:

O(n) 的做法,也是最简单的做法。最终通过终点的时候,一定是一个船后 面堵着剩余所有的船,那么影响时间的就只有最前面这辆船,所以对于每一辆船, 假设 是它是和 0 船堵在一起的最靠前的一辆船,那么可以计算出一个值,所有的船的计算值的 最大值就是答案。计算的时候一定不要忘了算上这堵在一起的一堆船的船身长度,因为最 后一辆船的车头通过终点,才算结束。

代码:

  1. #include<iostream>
  2. #include<cstdio>
  3. using namespace std;
  4. const int N=100005;
  5. double l[N],x[N],v[N],lin[N];
  6. int t,n;
  7. double ans;
  8. bool check(double tim)
  9. {
  10. for(int i=0;i<=n;i++) lin[i]=x[i];
  11. lin[n]=(lin[n]-tim * v[n]);
  12. for(int i=n-1;i>=0;i--)
  13. {
  14. double dis=tim*v[i];
  15. lin[i]=max(lin[i]-dis,lin[i+1]+l[i+1]);
  16. if(lin[i]>1e-3)return false;
  17. }
  18. return true;
  19. }
  20. void work()
  21. {
  22. double L=0.0,R=1e10;
  23. while((R-L)>1e-3)
  24. {
  25. double mid=(L+R)/(2.0);
  26. if(check(mid)) R=mid;
  27. else L=mid;
  28. }
  29. printf("%.3f\n",L);
  30. }
  31. int main()
  32. {
  33. #ifdef yilnr
  34. #else
  35. freopen("cruise.in","r",stdin);
  36. freopen("cruise.out","w",stdout);
  37. #endif
  38. scanf("%d",&t);
  39. while(t--)
  40. {
  41. scanf("%d",&n);
  42. for(int i=0;i<=n;i++)
  43. scanf("%lf",&l[i]);
  44. for(int i=0;i<=n;i++)
  45. scanf("%lf",&x[i]);
  46. for(int i=0;i<=n;i++)
  47. scanf("%lf",&v[i]);
  48. work();
  49. }
  50. fclose(stdin);
  51. fclose(stdout);
  52. return 0;
  53. }
  54. /*
  55. 1
  56. 2
  57. 1 2 2
  58. 10 7 1
  59. 6 2 1
  60. */

  

【csp模拟赛4】 珠江夜游 (cruise.cpp)-二分,贪心的更多相关文章

  1. Problem 1 珠江夜游 (cruise .cpp)———2019.10.6

    Problem 1 珠江夜游 (cruise.cpp)[题目描述]小 Z 放假后难得来一趟广州游玩,当然要吃遍广州各路美食小吃然后再到珠江新城看看远近闻名的小蛮腰啦!可当小 Z 一路吃吃吃以后,天渐渐 ...

  2. CSP模拟赛游记

    时间:2019.10.5 考试时间:100分钟(连正式考试时间的一半还没有到)题目:由于某些原因不能公开. 由于第一次接触NOIinux系统所以连怎么建文件夹,调字体,如何编译都不知道,考试的前半小时 ...

  3. 【csp模拟赛4】基站建设 (station.cpp)

    [题目描述] 小 Z 的爸爸是一位通信工程师,他所在的通信公司最近接到了一个新的通 信工程建设任务,他们需要在 C 城建设一批新的基站. C 城的城市规划做得非常好,整个城市被规整地划分为 8 行 8 ...

  4. 【csp模拟赛5】限制 (restrict.cpp)--数学

    自己看吧: 爆搜代码: //春水初涨-春林初盛-春风十里-不如你 //----hzwer // 这是啥子题,读不懂-- //题意有问题 -- #include<iostream> #inc ...

  5. 【csp模拟赛5】购物(shopping.cpp)--常规

    多项式,因为每次的x相同,所以把a和b相加就行了,然后找对称轴,找离对称轴最近的整数点,然而我却写了个暴力,没看x #include <iostream> #include <cst ...

  6. 【csp模拟赛4】旅行计划 (travelling.cpp)--欧拉回路

    [题目描述] 小 Z 打算趁着暑假,开启他的旅行计划.但与其他同学不同的是,小 Z 旅 行时并不关心到达了哪个网红景点打了哪些卡.小 Z 更关注沿路的风光,而且 小 Z 觉得,尽管多次到达同一个地方, ...

  7. 【csp模拟赛1】铁路网络 (network.cpp)

    [题目描述] 在暑假来临之际,小 Z 的地理老师布置了一个暑假作业,让同学们暑假期间 了解一下 C 国的铁路发展史.小 Z 在多番查证资料后发现,C 国在铁路发展初期, 铁路网络有着一个严密规整的结构 ...

  8. 【csp模拟赛1】不服来战 (challenge.cpp)

    [题目描述] 最近小 Z 和他的朋友都迷上了一款手机游戏:不服来战. 游戏的设定十分简单,在游戏开始时,会给出一排共 N 个灯,有的灯是开着 的有的是关着的,每个灯都有一个分数.而玩家可以进行任意次操 ...

  9. 【CSP模拟赛】Freda的迷宫(桥)

    题目描述 Freda是一个迷宫爱好者,她利用业余时间建造了许多迷宫.每个迷宫都是由若干房间和走廊构成的,每条走廊都连接着两个不同的房间,两个房间之间最多只有一条走廊直接相连,走廊都是双向通过.  黄昏 ...

随机推荐

  1. php验证手机号记录

    看完就忘记录一下 正则: $roue = "/^1[3-9]\d{9}$/"; 前后/...... / 是正则必须的规则 ^1 : 手机号的必须是1开头   ^: 字符串开始的地方 ...

  2. day04_XPATH提取数据

    1.XML简介 1.1.定义 ​ 可扩展标记语言(EXtensible Markup Language) 1.2.特点 一种标记语言,很类似 HTML XML 的标签需要我们自行定义 被设计为具有自我 ...

  3. Python 第一节随堂练习

    作业: 1 从键盘输入一个整数,判断该数字能否被2和3同时整除,能否被2整除,能否被3整除,不能被2和3整除,输出相应信息 1 my_num = int(input('请输入一个整数')) 2 if ...

  4. prometheus-常用资源对象

    监控 Kubernetes 常用资源对象 Prometheus 来自动发现 Kubernetes 集群的节点,用到了 Prometheus 针对 Kubernetes 的服务发现机制kubernete ...

  5. Oracle练习(一)

    Oracle 1.检索部门编号.部门名称.部门所在地及其每个部门的员工总数. select d.deptno,d.dname,d.loc,count(*) from emp e,dept d wher ...

  6. C#数字前补0

    [TestMethod] public void Test8() { ; string b = string.Format("{0:000000}", a); , '); }

  7. Windows编程 Windows程序的生与死(下)

    再谈程序之“死” 记得在第二回中我对程序的“死”只是一句话带过,因为我还没有铺垫好,好了现在我们可以详细的分析一下这个过程了. 这还要从while消息循环说起,还记得GetMessage函数吗?它是一 ...

  8. Git 集成 Araxis Merge 作为比较和合并GUI工具的配置 参考自https://www.kancloud.cn/leviio/git/369125

    Git 集成 Araxis Merge Win10下修改git全部配置文件方法Git 集成 Araxis Merge 作为比较和合并GUI工具的配置 那global对应的 ,gitconfig文件在哪 ...

  9. canvas-绘制矩形-读书笔记

    使用<canvas>元素,必须先设置其width和height属性,指定可以绘图的区域大小. 要在画布上绘图,需要取得绘图上下文,也就是要调用getContext()方法并传入上下文的名字 ...

  10. vue报类似警告Computed property "isLoading" was assigned to but it has no setter

    一.原因:一个计算属性,当计算传入的是一个函数,或者传入的是一个对象,而没有设置 setter,也就是 set 属性,当你尝试直接该改变这个这个计算属性的值,都会报这个警告,vuex还会出现通过com ...