很容易想到三分法求解,不过要分别在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. iOS常见面试题汇总

    iOS常见面试题汇总 1. 什么是 ARC? (ARC 是为了解决什么问题而诞生的?) ARC 是 Automatic Reference Counting 的缩写, 即自动引用计数. 这是苹果在 i ...

  2. Koajs原理

    Koajs让习惯阻塞式代码写法的同学感到很舒服,再也不用盖楼式的callback了,而且也不需要学习Promise的then,catch这些新东西. 但实际上,Koajs这样的写法有点像是语言的语法糖 ...

  3. windows 配置免安装 node

    1.下载 node.exe; 2.下载npm并解压;(NPM是一个Node包管理和分发工具) 3.创建单独文件夹 nodejs,将1.2步中的两个文件和一个文件夹放进该新建文件夹; 4.配置环境变量中 ...

  4. Junit的最简单样例:Hello world!

    我的技术博客经常被流氓网站恶意爬取转载.请移步原文:http://www.cnblogs.com/hamhog/p/3824934.html,享受整齐的排版.有效的链接.正确的代码缩进.更好的阅读体验 ...

  5. ZigBee 入网详解

    本文将根据Sniffer来详细解释ZigBee终端设备入网的整个流程,原创博文. 当协调器建立好网络后,终端设备执行zb_startrequest函数,准备入网时,他们两者之间详细的流程如下.

  6. Poj 2583 Series Determination

    1.Link: http://poj.org/problem?id=2583 2.Content: Series Determination Time Limit: 1000MS   Memory L ...

  7. 探索 Java 同步机制[Monitor Object 并发模式在 Java 同步机制中的实现]

    探索 Java 同步机制[Monitor Object 并发模式在 Java 同步机制中的实现] https://www.ibm.com/developerworks/cn/java/j-lo-syn ...

  8. 关于C#正则表达式MatchCollection类的总结,正则表达式的应用

    认识MatchCollection 类 表示通过以迭代方式将正则表达式模式应用于输入字符串所找到的成功匹配的集合. 命名空间:  System.Text.RegularExpressions 属性:C ...

  9. 斐波那契数 c 语言实现

    斐波那契数列,又称黄金数列,指的是这样一个数列:1.1.2.3.5.8.13.21.……在数学上,斐波纳契数列以如下被以递归的方法定义:F(1)=1,F(2)=1,F(n)=F(n-1)+F(n-2) ...

  10. Java.lang.RuntimeException: Unable to instantiate activity ComponentInfo

    如果你更新了ADT的新版本,而工程文件中使用了其他的jar包,也可能会出现"java.lang.RuntimeException: Unable to instantiate activit ...