为了方便,我们不妨设$\rm P \lt Q,R$

我们发现,有$\rm E$点在$\rm AB$上,$\rm F$点在$\rm CD$上,最优解一定是$\rm AE\rightarrow EF\rightarrow FD$,因为若中途离开某个传送带再回来,显然是不优的。

考虑固定点$E$,观察点$F$对答案造成的影响。

作过点$\rm E$作$\rm EG \perp CD$。

若$\rm F$在$\rm CG$上,单调性很显然。

若$\rm F$在$\rm GD$上,朝$\rm D$移动时。

  由于$\rm |FD|$在减少,而$\rm |EF|$在增加,且越增加越快,所以$\rm |FD| + |EF|$会先减少,后增加。

所以当$\rm E$点固定的时候,$\rm AE\rightarrow EF\rightarrow FD$的长度是个凹的单峰函数,我们可以用三分解决。

我们可以先三分$E$,再三分$F$来解决这题。什么?证明?我真的不会。

至于三分的时候怎么选坐标,可以按照端点横坐标纵坐标直接取$\frac{1}{3}$。

比如下图我们要找到$\rm CB$的$\frac{1}{3}$处,直接是$\rm B$和$\rm C$横坐标纵坐标分别三分之一即可。

明显有$\rm \triangle ABC\sim \triangle BDE$

所以$\rm D$点也在线段的$\frac{1}{3}$

 #include <bits/stdc++.h>

 using namespace std;

 const double eps = 1e-;

 double x[], y[], p, q, r;

 double dist(double xa, double ya, double xb, double yb) {
return sqrt((xa - xb) * (xa - xb) + (ya - yb) * (ya - yb));
} double check(double ex, double ey) {
double lx = x[], ly = y[], rx = x[], ry = y[];
while(fabs(rx - lx) > eps || fabs(ry - ly) > eps) {
double m1x = lx + (rx - lx) / , m1y = ly + (ry - ly) / ,
m2x = rx - (rx - lx) / , m2y = ry - (ry - ly) / ;
if(dist(ex, ey, m1x, m1y) / r + dist(m1x, m1y, x[], y[]) / q <
dist(ex, ey, m2x, m2y) / r + dist(m2x, m2y, x[], y[]) / q)
rx = m2x, ry = m2y;
else lx = m1x, ly = m1y;
}
return dist(ex, ey, lx, ly) / r + dist(lx, ly, x[], y[]) / q;
} int main() {
for(int i = ; i < ; i++) cin >> x[i] >> y[i];
cin >> p >> q >> r;
double lx = x[], ly = y[], rx = x[], ry = y[];
while(fabs(rx - lx) > eps || fabs(ry - ly) > eps) {
double m1x = lx + (rx - lx) / , m1y = ly + (ry - ly) / ,
m2x = rx - (rx - lx) / , m2y = ry - (ry - ly) / ;
if(dist(x[], y[], m1x, m1y) / p + check(m1x, m1y) <
dist(x[], y[], m2x, m2y) / p + check(m2x, m2y))
rx = m2x, ry = m2y;
else lx = m1x, ly = m1y;
}
printf("%.2lf\n", dist(x[], y[], lx, ly) / p + check(lx, ly));
return ;
}

【SCOI 2010】传送带的更多相关文章

  1. [SCOI 2010]传送带

    Description 题库链接 在一个 \(2\) 维平面上有两条传送带,每一条传送带可以看成是一条线段.两条传送带分别为线段 \(AB\) 和线段 \(CD\) .在 \(AB\) 上的移动速度为 ...

  2. SCOI 2010 连续攻击游戏(贪心,图论)

    SCOI 2010 连续攻击游戏 solution 直接就硬刚 我愿称贪心为暴力 因为题目中要求一定从小到大贪心,那么当前点的下标有能够选取的较大点,那么它一定可以和前面的一个较小点连接,所以可以直接 ...

  3. #10017 传送带(SCOI 2010)(三分套三分)

    [题目描述] 在一个 2 维平面上有两条传送带,每一条传送带可以看成是一条线段.两条传送带分别为线段 AB 和线段 CD.lxhgww 在 AB上的移动速度为 P ,在 CD 上的移动速度为 Q,在平 ...

  4. 【BZOJ 1857】【SCOI 2010】传送带

    三分套三分,虽然简单,但是也得掌握,,, 时间复杂度$O(log_{1.5}^2 n)$ 一开始WA好几次发现是快速读入里没有return,这样也能过样例?_(:3J∠)_ #include<c ...

  5. [SCOI 2010] 股票交易

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1855 [算法] 单调队列优化动态规划 [代码] #include<bits/s ...

  6. SCOI 2010 序列操作

    题目描述 lxhgww最近收到了一个01序列,序列里面包含了n个数,这些数要么是0,要么是1,现在对于这个序列有五种变换操作和询问操作: 0 a b 把[a, b]区间内的所有数全变成0 1 a b ...

  7. [SCOI 2010]字符串

    Description lxhgww最近接到了一个生成字符串的任务,任务需要他把n个1和m个0组成字符串,但是任务还要求在组成的字符串中,在任意的前k个字符中,1的个数不能少于0的个数.现在lxhgw ...

  8. 解题:SCOI 2010 序列操作

    题面 线段树......模板题(雾? 然而两种标记会互相影响,必须保证每次只放一个(不然就不知道怎么放了),具体的影响就是: 翻转标记会使得覆盖标记一起翻转,下放的时候就是各种swap 覆盖标记会抹掉 ...

  9. Scoi 2010 幸运数字

    [题目描述]在中国,很多人都把6和8视为是幸运数字!lxhgww也这样认为,于是他定义自己的“幸运号码”是十进制表示中只包含数字6和8的那些号码,比如68,666,888都是“幸运号码”!但是这种“幸 ...

随机推荐

  1. Alembic基本使用

    1.alembic init YOUR_ALEMBIC_DIR 该目录下会有alembic.ini以及YOUR_ALEMBIC_DIR的目录. alembic.ini 提供了一些基本的配置 YOUR_ ...

  2. ElasticSearch 5学习(5)——第一个例子

    想要知道ElasticSearch是如何使用的,最快的方式就是通过一个简单的例子,第一个例子将会包括基本概念如索引.搜索.和聚合等,需求是关于公司管理员工的一些业务. 员工文档索引 业务首先需要存储员 ...

  3. IOS 控制器View的创建方式(方式的优先级 、view的延迟加载)

    MJViewController的view的创建 的方式的优先级 控制器view的延迟加载 ● 控制器的view是延迟加载的:用到时再加载 ● 可以用isViewLoaded方法判断一个UIViewC ...

  4. JavaScript操作Array对象常用的方法

     转换方法 因为JavaScript内部机制(继承),所有的对象都具有toLocalString() .toString().valueOf()方法,Array也不例外so:var colors = ...

  5. C++手写快读详解(快速读入数字)

    众所周知,C++里是自带读入的(这不废话吗) 例如: int a; cin>>a; 这样的读入理解简单,适合初学者,但是非常慢. 再例如: int a; scanf("%d&qu ...

  6. 《GPU高性能编程CUDA实战中文》中第四章的julia实验

    在整个过程中出现了各种问题,我先将我调试好的真个项目打包,提供下载. /* * Copyright 1993-2010 NVIDIA Corporation. All rights reserved. ...

  7. java基础编程——获取栈中的最小元素

    题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)).   题目代码 /** * Created by YuKai Fan on 2018/9 ...

  8. Activiti学习记录(三)

    1.流程变量 1.1 流程图 流程变量在整个工作流中扮演很重要的作用.例如:请假流程中有请假天数.请假原因等一些参数都为流程变量的范围.流程变量的作用域范围是只对应一个流程实例.也就是说各个流程实例的 ...

  9. vue-awesome-swiper实现轮播图

    1.首先通过npm安装vue-awesome-swiper,我在项目中用的是2.6.7版本 npm install vue-awesome-swiper@2.6.7 –save 2. 在main.js ...

  10. 梁勇 java教材 编程练习题 第二章 2.6 键盘 读取一个在0 到 9999 之间的整数,并将该整数的各位数字相加。

    import java.util.Scanner; /** * 需求:从键盘输入任意0~9999之间的整数,输出这个整数各位数字之和. * 思路:方法一,使用扫描器Scanner类,扫描控制台输入流 ...