P2571 [SCOI2010]传送带

题意:

你要从 A 点到 D 点。有两条传送带:第一条从 A 到 B,速度为 pp,第二条从 C 到 D,速度为 q。不走传送带时速度为 r。求从 A 到 D 的最少时间。

题解:

很明显,答案路径是由AE+EF+FD组成的,E在AB上,F在CD上。
答案就是dis(A,E)/p+dis(E,F)/r+dis(F,D)/q
这是一个二元函数,E和F都是未知的
我们可以假设E已知,此时就是找一个F让f(E)=dis(E,F)/r+dis(F,D)/q最小,会发现这是一个单峰函数,也就是f(E)可以通过三分F得到最小值,而E也是未知量,我们还要取dis(A,E)/p+f(E)的最小值,我们发现这还是一个单峰函数,三分寻找E,就是答案
总结:三分套三分
怎么看出这个是单峰函数?我们一开始是将E和F一个固定,比如单看F,然后设F在CD上的比例,然后列出式子,感觉像单峰函数

模拟退火也可以做。。我还不会

代码:

三分模板要记熟

#include<bits/stdc++.h>
#define debug(a,b) printf("%s = %d\n",a,b);
using namespace std;
typedef long long ll;
typedef pair<int, int> PII;
clock_t startTime, endTime;
//Fe~Jozky
const ll INF_ll=1e18;
const int INF_int=0x3f3f3f3f;
inline ll read(){ll s=0,w=1ll;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')w=-1ll;ch=getchar();}while(ch>='0'&&ch<='9') s=s*10ll+((ch-'0')*1ll),ch=getchar();//s=(s<<3)+(s<<1)+(ch^48);return s*w;
}
void rd_test(){#ifdef ONLINE_JUDGE#elsestartTime = clock(); //计时开始freopen("2571.in","r",stdin);#endif
}
void Time_test(){#ifdef ONLINE_JUDGE#elseendTime = clock(); //计时结束printf("\n运行时间为:%lfs\n",(double)(endTime - startTime) / CLOCKS_PER_SEC);#endif
}
double Ax,Ay,Bx,By,Cx,Cy,Dx,Dy;
double P,Q,R;
const double eps=1e-9;
double get(double x1,double y1,double x2,double y2){return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}
double Time(double x1,double y1,double x2,double y2){double t2=get(x1,y1,x2,y2)/R;double t3=get(x2,y2,Dx,Dy)/Q;return t2+t3;
}
double work(double x,double y){double t1=get(Ax,Ay,x,y)/P;//第一段double lx=Cx,ly=Cy,rx=Dx,ry=Dy;while(get(lx,ly,rx,ry)>eps){double lmidx=lx+(rx-lx)/3.0;double lmidy=ly+(ry-ly)/3.0;double rmidx=rx-(rx-lx)/3.0;double rmidy=ry-(ry-ly)/3.0;double ans1=Time(x,y,lmidx,lmidy);double ans2=Time(x,y,rmidx,rmidy); if(ans2-ans1>eps){rx=rmidx;ry=rmidy;}else {lx=lmidx;ly=lmidy;}}return t1+Time(x,y,lx,ly);
}
int main()
{//rd_test();cin>>Ax>>Ay>>Bx>>By;cin>>Cx>>Cy>>Dx>>Dy;cin>>P>>Q>>R; double lx,ly,rx,ry;lx=Ax,ly=Ay;rx=Bx,ry=By;while(get(lx,ly,rx,ry)>eps){double lmidx=lx+(rx-lx)/3.0;double lmidy=ly+(ry-ly)/3.0;double rmidx=rx-(rx-lx)/3.0;double rmidy=ry-(ry-ly)/3.0;double ans1=work(lmidx,lmidy);double ans2=work(rmidx,rmidy); if(ans2-ans1>eps){rx=rmidx;ry=rmidy;}else {lx=lmidx;ly=lmidy;}}printf("%.2lf\n",work(lx,ly));return 0;//Time_test();
}

P2571 [SCOI2010]传送带相关推荐

  1. [BZOJ1857][Scoi2010]传送带

    1857: [Scoi2010]传送带 Time Limit: 1 Sec  Memory Limit: 64 MB Submit: 1786  Solved: 981 [Submit][Status ...

  2. BZOJ1857 Scoi2010 传送带 【三分】

    BZOJ1857 Scoi2010 传送带 Description 在一个2维平面上有两条传送带,每一条传送带可以看成是一条线段.两条传送带分别为线段AB和线段CD.lxhgww在AB上的移动速度为P ...

  3. bzoj1857 [Scoi2010]传送带

    1857: [Scoi2010]传送带 Time Limit: 1 Sec  Memory Limit: 64 MB Submit: 1635  Solved: 909 [Submit][Status ...

  4. BZOJ1857:[SCOI2010]传送带——题解

    http://www.lydsy.com/JudgeOnline/problem.php?id=1857 Description 在一个2维平面上有两条传送带,每一条传送带可以看成是一条线段.两条传送 ...

  5. [SCOI2010]传送带

    在一个2维平面上有两条传送带,每一条传送带可以看成是一条线段.两条传送带分别为线段AB和线段CD.lxhgww在AB上的移动速度为P,在CD上的移动速度为Q,在平面上的移动速度R.现在lxhgww想从 ...

  6. OI每周刷题记录——lrllrl

    看这标题就知道我是模仿的hzwer大佬,远程%%% 大佬的OI经历让蒟蒻我深受感触,为了晚一些AFO本蒟蒻也得加油了 从高二上期第一周开始计数,每个星期天更一次,一直更到我AFO 如果这是我此生最后一 ...

  7. 【水】【SCOI】 精简题解

    第二弹 [SCOI2009]生日快乐 搜索.递归划分问题. [SCOI2009]游戏 记忆化搜索.枚举素因子,DP. [SCOI2009]windy数 数位DP,分块统计. [SCOI2009]最长距 ...

  8. 语法入门*算法入门题单

    作者:王清楚 链接:https://ac.nowcoder.com/discuss/817596?type=101&order=0&pos=1&page=4&chann ...

  9. 【新手上路】语法入门算法入门题单

    作者:王清楚 链接:[新手上路]语法入门&算法入门题单_ACM竞赛_ACM/CSP/ICPC/CCPC/比赛经验/题解/资讯_牛客竞赛OJ_牛客网 来源:牛客网 介绍:本题单分为语法入门和算法 ...

最新文章

  1. 注释转换——(小项目)
  2. solr mysql 导入命令_(solr系列:四)将mysql数据库中的数据导入到solr中及删除solr中导入的数据...
  3. springboot 定制个性 banner
  4. m 文件 dll matlab 中调用_Java与MatLab混编
  5. 51单片机学习笔记(郭天祥版)(9)——IIC、EEPROM
  6. palm基础----8 国际化
  7. 正则表达式中或关系表示及查找英文字母最后一个
  8. python编码规范总结、python编码转换
  9. java多线程总结一:线程的两种创建方式及比较
  10. 不用MindManager打开mmap文件
  11. 推荐一本 python自动化框架pytest -上海悠悠
  12. Gabor变换(2)
  13. js 字符串转二维数组
  14. 英特尔CPU详细参数表(新老CPU详细对照表)
  15. 安卓多渠道打包(三)360加固多渠道打包
  16. Nginx转发https访问的实现
  17. 汽车音响的各个按钮的功能汇总
  18. SAP ABAP——SAP简介(一)【SAP发展历程】
  19. 关于py2neo中的merge,create,当反复执行时,会出现什么。。。
  20. win7桌面便笺:启动时提示windows7部分便笺的元数据已被损坏

热门文章

  1. 揭秘神仙高校的课堂!网友跪了:这就是差距啊!
  2. 如何有效利用碎片时间?这里有个办法
  3. 硕士论文研究「AI预测性取向」:化妆等因素并不影响判断
  4. 大数据时代,还不认识这些数据分析工具?
  5. python 绘制围棋棋盘_围棋之规则基础(一)
  6. 自拟计算机作文100字,我的电脑作文100字五篇
  7. qbuttongroup如何都不选中_全程马拉松,半程马拉松该如何跑?很多人都不知道这些细节...
  8. mysql decimal型转化为float_5分钟搞懂MySQL数据类型之数值型DECIMAL类型
  9. Java当中编码和解码(以及出现乱编码的原因)
  10. 「软件项目管理」成本估算模型——Walston-Felix模型和COCOMO Ⅱ模型