传送带(bzoj 1857)
Description
Input
Output
Sample Input
100 0 100 100
2 2 1
Sample Output
HINT
对于100%的数据,1<= Ax,Ay,Bx,By,Cx,Cy,Dx,Dy<=1000
1<=P,Q,R<=10
/*
路线可以分为三部分:在AB上的,CD上的,还有在平面上的。
可以三分AB上的断点和CD上的断点。
*/
#include<iostream>
#include<cstdio>
#include<cmath>
#define eps 1e-9
using namespace std;
double ax,ay,bx,by,cx,cy,dx,dy,P,Q,R,ans;
double calc(double x1,double y1,double x2,double y2){
return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}
double sa2(double x,double y){//CD无斜率
double m1,m2,k,t1,t2,l,r;
l=min(cy,dy),r=max(cy,dy);
while(l+eps<r){
m1=(*l+r)/,m2=(l+*r)/;
t1=calc(cx,m1,dx,dy)/Q+calc(cx,m1,x,y)/R;
t2=calc(cx,m2,dx,dy)/Q+calc(cx,m2,x,y)/R;
if(t1<t2) r=m2;
else l=m1;
}
t1=calc(cx,l,dx,dy)/Q+calc(cx,l,x,y)/R;
return t1;
}
double sanfen2(double x,double y){//CD有斜率
if(cx==dx) return sa2(x,y);
double m1,m2,k,t1,t2,l,r,b;
l=min(cx,dx),r=max(cx,dx);
k=(cy-dy)/(cx-dx);
b=cy-k*cx;
while(l+eps<r){
m1=(*l+r)/,m2=(l+*r)/;
t1=calc(m1,m1*k+b,dx,dy)/Q+calc(m1,m1*k+b,x,y)/R;
t2=calc(m2,m2*k+b,dx,dy)/Q+calc(m2,m2*k+b,x,y)/R;
if(t1<t2) r=m2;
else l=m1;
}
t1=calc(l,l*k+b,dx,dy)/Q+calc(l,l*k+b,x,y)/R;
return t1;
}
void sanfen1(){//AB有斜率
double m1,m2,k,t1,t2,l,r,b;
l=min(ax,bx),r=max(ax,bx);
k=(ay-by)/(ax-bx);
b=ay-k*ax;
while(l+eps<r){
m1=(*l+r)/,m2=(l+*r)/;
t1=sanfen2(m1,k*m1+b)+calc(m1,m1*k+b,ax,ay)/P;
t2=sanfen2(m2,m2*k+b)+calc(m2,m2*k+b,ax,ay)/P;
if(t1<t2) r=m2;
else l=m1;
}
t1=sanfen2(l,l*k+b)+calc(l,l*k+b,ax,ay)/P;
ans=min(ans,t1);
}
void sa1(){//AB无斜率.
double m1,m2,k,t1,t2,l,r;
l=min(ay,by),r=max(ay,by);
while(l+eps<r){
m1=(*l+r)/,m2=(l+*r)/;
t1=sanfen2(ax,m1)+calc(ax,m1,ax,ay)/P;
t2=sanfen2(ax,m2)+calc(ax,m2,ax,ay)/P;
if(t1<t2) r=m2;
else l=m1;
}
t1=sanfen2(ax,l)+calc(ax,l,ax,ay)/P;
ans=min(ans,t1);
}
int main(){
cin>>ax>>ay>>bx>>by>>cx>>cy>>dx>>dy;
cin>>P>>Q>>R;
ans=calc(ax,ay,dx,dy)/R;
if(ax!=bx) sanfen1();
else sa1();
printf("%.2lf",ans);
return ;
}
传送带(bzoj 1857)的更多相关文章
- BZOJ 1857: [Scoi2010]传送带
		二次联通门 : BZOJ 1857: [Scoi2010]传送带 /* BZOJ 1857: [Scoi2010]传送带 三分套三分 可能是吧..dalao们都说明显是一个单峰函数 可是我证不出来.. ... 
- [BZOJ 1857] 传送带
		Link: BZOJ 1857 传送门 Solution: 首先中间的两个拐点$C,D$肯定都在传送带$A,B$上 接下来感性发现固定点A/C,另一个点C/D时间随位置的变化为单峰函数 这样就是三分套 ... 
- bzoj 1857: [Scoi2010]传送带  三分
		题目链接 1857: [Scoi2010]传送带 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 934 Solved: 501[Submit][Stat ... 
- Bzoj 1857: [Scoi2010]传送带(三分套三分)
		1857: [Scoi2010]传送带 Time Limit: 1 Sec Memory Limit: 64 MB Description 在一个2维平面上有两条传送带,每一条传送带可以看成是一条线段 ... 
- BZOJ 1857 传送带 (三分套三分)
		在一个2维平面上有两条传送带,每一条传送带可以看成是一条线段.两条传送带分别为线段AB和线段CD.lxhgww在AB上的移动速度为P,在CD上的移动速度为Q,在平面上的移动速度R.现在lxhgww想从 ... 
- BZOJ 1857: [Scoi2010]传送带(三分套三分)
		Time Limit: 1 Sec Memory Limit: 64 MB Submit: 2549 Solved: 1370 [Submit][Status][Discuss] Descriptio ... 
- 【BZOJ 1857】【SCOI 2010】传送带
		三分套三分,虽然简单,但是也得掌握,,, 时间复杂度$O(log_{1.5}^2 n)$ 一开始WA好几次发现是快速读入里没有return,这样也能过样例?_(:3J∠)_ #include<c ... 
- bzoj 1857
		三分,对于单凸的函数(单调的也可以),可以找出最值. 这道题可以感性认识一下...... /****************************************************** ... 
- bzoj 1857 三分套三分
		题目大意 在一个2维平面上有两条传送带,每一条传送带可以看成是一条线段.两条传送带分别为线段AB和线段CD.lxhgww在AB上的移动速度为P,在CD上的移动速度为Q,在平面上的移动速度R.现在lxh ... 
随机推荐
- 分享一个漂亮按钮插件FancyButtons
			一转眼,2018年的第10天就这样过去了.回看17年,曾经做了些啥都忘记了,就像每一天写日志时的样子(双手放在键盘上,怒着嘴,抬着头,望着天花板), 然后突然记得好像好久没有写随笔了(@_@).自从配 ... 
- struts2、hibernate的知识点
			以下内容是我在复习struts2.hibernate和spring的时候记下得到,部分书上找不到的内容来自网络 以下是网络部分的原文网站: http://blog.csdn.net/frankaqi/ ... 
- Mysql的一些纪要
			unsigned 整型的每一种都分无符号(unsigned)和有符号(signed)两种类型(float和double总是带符号的),在默认情况下声明的整型变量都是有符号的类型(char有点特别),如 ... 
- 八、Linux 用户和用户组管理
			Linux 用户和用户组管理 Linux系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统. 用户的账号一方面可以帮助 ... 
- 动态拼接SQL语句
			1.参考官方文档 ? if:字符判断 ? choose (when, otherwise):分支选择 ? trim (where, set):字符串截取:其中where标签封装查询条件,set标签封装 ... 
- nova boot添加volume_type参数支持
			早前由于添加了全SSD的高性能Ceph集群,区别于现有的HDD集群,在OpenStack端需要能够选择使用两种集群.Cinder配置多Ceph后端的文档早已整理,整理文件夹时发现这篇为nova boo ... 
- 4 Template层 -定义模板
			1.模板介绍 作为Web框架,Django提供了模板,可以很便利的动态生成HTML 模版系统致力于表达外观,而不是程序逻辑 模板的设计实现了业务逻辑(view)与显示内容(template)的分离,一 ... 
- TCP/IP网络编程之进程间通信
			进程间通信基本概念 进程间通信意味着两个不同进程间可以交换数据,为了完成这一点,操作系统中应提供两个进程可以同时访问的内存空间.但我们知道,进程具有完全独立的内存结构,就连通过fork函数创建的子进程 ... 
- Django templates(模板)
			为什么用templates? views.py视图函数是用来写Python代码的,HTML可以被直接硬编码在views.py之中.如下: import datetime def current_tim ... 
- 3 - JVM随笔分类(gc.log ,VisualVM插件介绍,VisualVM远程连接方式介绍)
			gc.log 354.2 KB 对于对应用的监控上可以使用Jdk自带的VisualVM来做可视化监控,可以查看当前服务应用进程的堆大小的走向,以及类的加载数量等,除此之外,VisualVM可以支持很多 ... 
