很容易想到三分法求解,不过要分别在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. 利用google api生成二维码名片例子

    二维条码/二维码可以分为堆叠式/行排式二维条码和矩阵式二维条码.堆叠式/行排式二维条码形态上是由多行短截的一维条码堆叠而成:矩阵式二维条码以矩阵的形式组成,在矩阵相应元素位置上用“点”表示二进制“1” ...

  2. 承接VR/AR内容应用定制需求

    业务范围: 1 承接VR/AR内容应用定制需求: 教育培训.建筑建设.旅游体验.课件教学系统.交通车辆仿真,模拟驾驶系统.游戏等.2 各类最新VR设备,例如GearVR.HTC vive.Oculus ...

  3. 第六章 Qt布局管理器Layout

    第六章 Qt布局管理器Layout 大家有没有发现一个现象,我们放置一个组件,给组件最原始的定位是给出这个控件的坐标和宽高值,这样Qt就知道这个组件的位置.当用户改变窗口的大小,组件还静静地呆在原来的 ...

  4. js 中的正则表达式

    一:正则表达式 定义:记录文本规则的代码 作用:表单验证,爬虫技术,可以对目标的内容进行替换. 二:正则表达式的组成 1:普通字符组成正则 浏览器的输出 2:定义字符集组成正则 3:特殊字符集组成正则 ...

  5. apache重写

    ---- 本文旨在提供如何用Apache重写规则来解决一些常见的URL重写方法的问题,通过常见的实例给用户一些使用重写规则的基本方法和线索. 一.为什么需要用重写规则 ---- 网站的生命在于不断地进 ...

  6. sql2005下载和安装

    下载地址:个人百度网盘 http://pan.baidu.com/s/1kTvKIZd sql05安装包.rar 1.54G这个 安装方法: 先安装Tool 在安装Server http://bbs. ...

  7. 压力测试工具siege的用法

    Siege是linux下的一个web系统的压力测试工具,支持多链接,支持get和post请求,可以对web系统进行多并发下持续请求的压力测试. 安装 Siege 01 02 03 04 #wget h ...

  8. Node.js 【Stream之笔记】

    从Node.js API文档中可知, 'A stream is an abstract interface implemented by various objects in Node. For ex ...

  9. TImage 的一些操作

    //给 image上写数字. Image1.Picture.Bitmap.Height:= Image1.Height; Image1.Picture.Bitmap.Width:= Image1.Wi ...

  10. Spark Streaming揭秘 Day8 RDD生命周期研究

    Spark Streaming揭秘 Day8 RDD生命周期研究 今天让我们进一步深入SparkStreaming中RDD的运行机制.从完整的生命周期角度来说,有三个问题是需要解决的: RDD到底是怎 ...