我比较快速的想到了三分,但是我是从0到2*pi区间进行三分,并且漏了一种点到边距离的情况,一直WA了好几次

后来画了下图才发现,0到2*pi区间内是有两个极值的,每个半圆存在一个极值

以下是代码

#include <cstdio>
#include <cmath>
#include <algorithm>
#define pi acos(-1.0)
using namespace std; typedef struct
{
double x;
double y;
}point; typedef struct
{
double x;
double y;
double r;
}circle; typedef struct
{
point s;
point e;
}line; double dis(point a,point b)
{
return sqrt((a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y));
} double cal(point st,line ed,circle c,double t)
{
point p;
p.x=c.x+cos(t)*c.r;
p.y=c.y+sin(t)*c.r;
if(fabs(ed.s.x-ed.e.x)<1e-8)
{
if(p.y>ed.s.y&&p.y<ed.e.y)
{
return dis(p,st)+fabs(p.x-ed.s.x);
}
else
{
double t=min(dis(p,ed.s),dis(p,ed.e));
return dis(p,st)+t;
} }
if(fabs(ed.s.y-ed.e.y)<1e-8)
{
if(p.x>ed.s.x&&p.x<ed.e.x)
{
return dis(p,st)+fabs(p.y-ed.s.y);
}
else
{
double t=min(dis(p,ed.s),dis(p,ed.e));
return dis(p,st)+t;
}
}
return -1;
} double solve1(point st,line ed,circle c)
{
double L=0,R=pi,mid=(L+R)/2,midmid=(mid+R)/2;
while(R-L>1e-10)
{
if(cal(st,ed,c,mid)<cal(st,ed,c,midmid))R=midmid;
else L=mid;
mid=(L+R)/2;
midmid=(R+mid)/2;
}
return cal(st,ed,c,midmid);
} double solve2(point st,line ed,circle c)
{
double L=pi,R=2*pi,mid=(L+R)/2,midmid=(mid+R)/2;
while(R-L>1e-10)
{
if(cal(st,ed,c,mid)<cal(st,ed,c,midmid))R=midmid;
else L=mid;
mid=(L+R)/2;
midmid=(R+mid)/2;
}
return cal(st,ed,c,midmid);
} int main()
{
double m,x[2],y[2];
point st;
circle cir;
line a[4];
while(scanf("%lf%lf",&st.x,&st.y)==2)
{
if(!st.x&&!st.y)break;
scanf("%lf%lf%lf",&cir.x,&cir.y,&cir.r);
scanf("%lf%lf",&x[0],&y[0]);
scanf("%lf%lf",&x[1],&y[1]);
if(x[0]>x[1]) swap(x[0],x[1]);
if(y[0]>y[1]) swap(y[0],y[1]);
a[0].s.x=x[0];a[0].s.y=y[0];
a[0].e.x=x[0];a[0].e.y=y[1];
a[1].s.x=x[0];a[1].s.y=y[0];
a[1].e.x=x[1];a[1].e.y=y[0];
a[2].s.x=x[1];a[2].s.y=y[0];
a[2].e.x=x[1];a[2].e.y=y[1];
a[3].s.x=x[0];a[3].s.y=y[1];
a[3].e.x=x[1];a[3].e.y=y[1];
m=1e18;
for(int i=0;i<4;i++)
{
double t=solve1(st,a[i],cir);
if(t<m)m=t;
t=solve2(st,a[i],cir);
if(t<m)m=t;
}
printf("%.2lf\n",m);
}
return 0;
}

HDU 4454 - Stealing a Cake(三分)的更多相关文章

  1. hdu 4454 Stealing a Cake (三分)

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

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

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

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

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

  4. hdu 4454 Stealing a Cake 三分法

    很容易想到三分法求解,不过要分别在0-pi,pi-2pi进行三分. 另外也可以直接暴力枚举…… 代码如下: #include<iostream> #include<stdio.h&g ...

  5. hdu 4454 Stealing a Cake

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

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

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

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

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

  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. [置顶] C++之TinyXML的使用介绍

    一.引子: 最近在做GBT28181国标平台对接的工作,涉及到一些进程间消息通讯,消息体有xml格式,之前测试的时候都是拿他们当做字符串去解析,现在正儿八经地开发的时候,就想到了用xml库去解析,由于 ...

  2. Effective C++_笔记_条款09_绝不在构造和析构过程中调用virtual函数

    (整理自Effctive C++,转载请注明.整理者:华科小涛@http://www.cnblogs.com/hust-ghtao/) 为方便采用书上的例子,先提出问题,在说解决方案. 1 问题 1: ...

  3. Servlet的学习之Request请求对象(3)

    本篇接上一篇,将Servlet中的HttpServletRequest对象获取RequestDispatcher对象后能进行的[转发]forward功能和[包含]include功能介绍完. 首先来看R ...

  4. Appium Server 传递Android参数

    Appium  server Capabilities 传递参数    Android 特定 Android Only Capability Description Values appActivit ...

  5. 《转》OpenStack Live Migration

    This post is based assumption that KVM as hypervisor, and Openstack is running in Grizzly on top of ...

  6. JVM学习笔记(一)------的基本结构

    从Java视台的逻辑结构.我们能够从图中学习JVM: 您可以从图表清楚地看到Java该平台包括各种逻辑模块.还可以学习JDK与JRE差异 于JVM它们的物理结构,我们可以看一下从图计划: 为JVM学习 ...

  7. SVM入门(十)将SVM用于多类分类

    源地址:http://www.blogjava.net/zhenandaci/archive/2009/03/26/262113.html 从 SVM的那几张图可以看出来,SVM是一种典型的两类分类器 ...

  8. 所有CN_消息的说明

    Notification Message Corresponding WindowsConstant Message Description cn_CharToItem wm_CharToItem T ...

  9. KMP算法(具体求串的next[n])

     怎么求串的模式值next[n]   )next[0]= -1  意义:不论什么串的第一个字符的模式值规定为-1. )next[j]= -1   意义:模式串T中下标为j的字符,假设与首字符 同样,且 ...

  10. git flow 的使用

     在这里主要讲一下我在项目中用到的关于gitflow的使用方法.   公司的项目中,专门有一台用来存放版本号库的server,路径是在默认的安装文件夹/opt/git/,那么在使用的时候,假设你是 ...