很容易想到三分法求解,不过要分别在0-pi,pi-2pi进行三分。

另外也可以直接暴力枚举……

代码如下:

 #include<iostream>
#include<stdio.h>
#include<algorithm>
#include<iomanip>
#include<cmath>
#include<cstring>
#include<vector>
#define ll __int64
#define pi acos(-1.0)
#define MAX 50000
using namespace std;
struct point
{
double x,y;
point(double _x=,double _y=){
x=_x;
y=_y;
}
point operator-(point a){
return point(x-a.x,y-a.y);
}
point operator+(point a){
return point(x+a.x,y+a.y);
}
double operator*(point a){
return (x*a.x+y*a.y);
}
}p1,p2,p;
double x,y,r;
double dis2(point a,point b)
{
return sqrt((a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y));
}
double dis(point a, point b, point c)
{
point ab = b - a;
point ac = c - a;
double f = ab*ac;
if (f<) return dis2(c, a);//C1处的点
double d = ab*ab;
if ( f>d) return dis2(c, b);//C2处的点,d=f*cos(theta)
f = f/d;
ab.x*=f;ab.y*=f;
point D = a + ab; // c在ab线段上的投影点
return dis2(c, D);
}
double line(point a)
{
point b,c;
b.x=min(p1.x,p2.x);
b.y=max(p1.y,p2.y);
c.x=max(p1.x,p2.x);
c.y=min(p1.y,p2.y);
double MIN1,MIN2;
MIN1=min(dis(p2,c,a),dis(p1,c,a));
MIN2=min(dis(p1,b,a),dis(p2,b,a));
return min(MIN1,MIN2);
}
point get(double a)
{
return point(x+r*cos(a),y+r*sin(a));
}
double solve()
{
double r,l,mid,midmid,t1,t2,ans1,ans2;
point m1,m2;
r=pi;l=;
while(r-l>=1e-){
mid=(r+l)/;
midmid=(mid+r)/;
m1=get(mid);
m2=get(midmid);
t1=line(m1)+dis2(m1,p);
t2=line(m2)+dis2(m2,p);
if(t1>t2) l=mid;
else r=midmid;
}
ans1=t1;
r=*pi;l=pi;
while(r-l>=1e-){
mid=(r+l)/;
midmid=(mid+r)/;
m1=get(mid);
m2=get(midmid);
t1=line(m1)+dis2(m1,p);
t2=line(m2)+dis2(m2,p);
if(t1>t2) l=mid;
else r=midmid;
}
ans2=t1;
return min(ans1,ans2);
}
int main(){
while(cin>>p.x>>p.y){
if(fabs(p.x)<1e-&&fabs(p.y)<1e-) break;
cin>>x>>y>>r>>p1.x>>p1.y>>p2.x>>p2.y;
point temp;
temp.x=p1.x;temp.y=p1.y;
p1.x=min(p1.x,p2.x);p1.y=min(p1.y,p2.y);
p2.x=max(temp.x,p2.x);p2.y=max(temp.y,p2.y);
printf("%.2lf\n",solve());
}
return ;
}

hdu 4454 Stealing a Cake 三分法的更多相关文章

  1. hdu 4454 Stealing a Cake(三分之二)

    pid=4454" target="_blank" style="">题目链接:hdu 4454 Stealing a Cake 题目大意:给定 ...

  2. hdu 4454 Stealing a Cake (三分)

    Stealing a Cake Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  3. hdu 4454 Stealing a Cake(三分法)

    给定一个起始点,一个矩形,一个圆,三者互不相交.求从起始点->圆->矩形的最短距离. 自己画一画就知道距离和会是凹函数,不过不是一个凹函数.按与水平向量夹角为圆心角求圆上某点坐标,[0, ...

  4. HDU 4454 Stealing a Cake(枚举角度)

    题目链接 去年杭州现场赛的神题..枚举角度..精度也不用注意.. #include <iostream> #include <cstdio> #include <cstr ...

  5. HDU 4454 Stealing a Cake --枚举

    题意: 给一个点,一个圆,一个矩形, 求一条折线,从点出发,到圆,再到矩形的最短距离. 解法: 因为答案要求输出两位小数即可,精确度要求不是很高,于是可以试着爆一发,暴力角度得到圆上的点,然后求个距离 ...

  6. hdu 4454 Stealing a Cake

    简单的计算几何: 可以把0-2*pi分成几千份,然后找出最小的: 也可以用三分: #include<cstdio> #include<cmath> #include<al ...

  7. HDU 4454 - Stealing a Cake(三分)

    我比较快速的想到了三分,但是我是从0到2*pi区间进行三分,并且漏了一种点到边距离的情况,一直WA了好几次 后来画了下图才发现,0到2*pi区间内是有两个极值的,每个半圆存在一个极值 以下是代码 #i ...

  8. hdu 4454 Stealing a Cake(计算几何:最短距离、枚举/三分)

    题意:已知起点.圆.矩形,要求计算从起点开始,经过圆(和圆上任一点接触即可),到达矩形的路径的最短距离.(可以穿过园). 分析:没什么好的方法,凭感觉圆上的每个点对应最短距离,应该是一个凸函数,用三分 ...

  9. hdu 4771 Stealing Harry Potter&#39;s Precious(bfs)

    题目链接:hdu 4771 Stealing Harry Potter's Precious 题目大意:在一个N*M的银行里,贼的位置在'@',如今给出n个宝物的位置.如今贼要将全部的宝物拿到手.问最 ...

随机推荐

  1. 第三十六篇、webService

    在很多的情况下,我们会常常遇到webservive写的接口,往往这种情况下,我们就需要拼接一段报文去与服务器对接 首先要明白webService的工作原理,,,(http://www.cnblogs. ...

  2. 第三十一篇、iOS 9版本适配

    1.网络适配(强制回退HTTP) 为了强制增强数据访问安全, iOS9 默认会把 所有的http请求 所有从NSURLConnection . CFURL . NSURLSession发出的 HTTP ...

  3. Cocos2d-x中SQLite数据库管理工具

    数据库创建完成后,我们可能需要看看数据库中数据是否成功插入,很多人喜欢使用图形界面工具来管理SQLite数据库.SQLite图形界面管理工具有很多,我推荐使用SQLiteStudio工具,下载地址ht ...

  4. 使用Emmet(前身Zen Coding)加速Web前端开发

    Emmet插件以前被称作为Zen Coding,是一个文本编辑器的插件,它可以帮助您快速编写HTML和CSS代码,从而加速Web前端开发.早在2009年,Sergey Chikuyonok写过一篇文章 ...

  5. 基本排序算法的java实现

    本例子实现了一些常见的排序算法,注释中也有一些关于这些算法的思想的描述,这里不做多说,直接上代码. import java.awt.List; import java.util.ArrayList; ...

  6. java查询WFS服务

    在我们访问wfs服务时候,有时候会遇到前台访问时候的跨域问题.这里给出java访问的一个小例子. import java.io.BufferedReader; import java.io.IOExc ...

  7. 在Apache中开启虚拟主机

    最近在自学LAMP,在Apache中尝试着开启虚拟主机的时候,遇到了挺多麻烦的,这里也顺便总结一下,在Apache中开启虚拟主机的时候,主要有下面几个步骤: 1.新建一个文件夹作为虚拟主机,用来存储网 ...

  8. SQL Server 2008 R2密钥序列号

    SQL Server 2008 R2密钥序列号 序列号: 开发版(Developer): PTTFM-X467G-P7RH2-3Q6CG-4DMYB 企业版(Enterprise): JD8Y6-HQ ...

  9. 前端构建工具gulp入门教程

    本文假设你之前没有用过任何任务脚本(task runner)和命令行工具,一步步教你上手Gulp.不要怕,它其实很简单,我会分为五步向你介绍gulp并帮助你完成一些惊人的事情.那就直接开始吧. 第一步 ...

  10. 部门招聘开发人员(python相关)

    岗位职责: 1.参与需求分析,产品设计,功能开发: 2.负责系统平台的日常维护: 3.与团队技术交流,共同进步 任职要求: 1.精通Python:对Python有兴趣. 2.熟悉MVC架构,精通Dja ...