简单的计算几何;

可以把0-2*pi分成几千份,然后找出最小的;

也可以用三分;

 #include<cstdio>
#include<cmath>
#include<algorithm>
#define pi acos(-1)
#define eps 1e-6
using namespace std; struct node
{
double x,y;
node(double x=,double y=):x(x),y(y){ }
bool operator<(const node &t)const
{
if(x==t.x)return y<t.y;
else return x<t.x;
}
};
node operator-(node u,node v){return node(u.x-v.x,u.y-v.y);}
node operator+(node u,node v){return node(u.x+v.x,u.y+v.y);}
node operator*(node u,double v){return node(u.x*v,u.y*v);}
node operator/(node u,double v){return node(u.x/v,u.y/v);}
int dcmp(double x)
{
if(fabs(x)<eps)return ;
else return x<?-:;
}
bool operator==(const node& a,const node& b)
{
return dcmp(a.x-b.x)== && dcmp(a.y-b.y)==;
}
double dot(node a,node b){return a.x*b.x+a.y*b.y;}
double length(node a){return sqrt(dot(a,a));}
double cross(node a,node b){return a.x*b.y-a.y*b.x;}
double disofnode(node p,node a,node b)
{
if(a==b)return length(p-a);
node v1=b-a,v2=p-a,v3=p-b;
if(dcmp(dot(v1,v2))<)return length(v2);
else if(dcmp(dot(v1,v3))>)return length(v3);
else return fabs(cross(v1,v2))/length(v1);
} node a,yuan,d[];
double r;
double dis(double alph)
{
node tmp;
tmp.x=yuan.x+r*cos(alph);
tmp.y=yuan.y+r*sin(alph);
double dd1=min(disofnode(tmp,d[],d[]),disofnode(tmp,d[],d[]));
double dd2=min(disofnode(tmp,d[],d[]),disofnode(tmp,d[],d[]));
double ret=min(dd1,dd2);
return (ret+length(a-tmp));
} int main()
{
while(scanf("%lf%lf",&a.x,&a.y))
{
if(dcmp(a.x)== && dcmp(a.y)==)break;
scanf("%lf%lf",&yuan.x,&yuan.y);
scanf("%lf",&r);
double x1,x2,y1,y2;
scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);
d[].x=x1,d[].y=y1;
d[].x=x2,d[].y=y1;
d[].x=x2,d[].y=y2;
d[].x=x1,d[].y=y2;
sort(d,d+);
double mi=0.0,ma=*pi;
double ans=9999999999.0;
for(int i=;i<=;i++)
{
double mm=(*pi*i)/;
double fd=dis(mm);
ans=min(ans,fd);
// double m1=mi+(ma-mi)/3;//三分的代码
// double m2=ma-(ma-mi)/3;
// if(dis(m1)>dis(m2))mi=m1;
// else ma=m2;
}
printf("%.2lf\n",ans);
}
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(枚举角度)

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

  4. HDU 4454 Stealing a Cake --枚举

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

  5. hdu 4454 Stealing a Cake 三分法

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

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

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

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

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

  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. OpenSSH Client信息泄露和缓冲区溢出漏洞

    一.风险简述: 2016年1月14日OpenSSH发布官方公告称,OpenSSH Client 5.4~7.1版本中未公开说明的功能(Roaming)存在信息泄漏和缓冲区溢出漏洞,此漏洞可能导致您通过 ...

  2. 九度 1371 最小的K个数

    题目描述:输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,. 输入: 每个测试案例包括2行:第一行为2个整数n,k(1<= ...

  3. webstom 配置git 后左侧菜单栏配色调整

    ws配置了git进行版本管理,但是最近改了主题,发现左侧列表的文件名的颜色都是一个颜色了.我想要的是,对未提交的文件用颜色区分,新建的,修改的,冲突的分别设置不同的颜色,不知在哪里能设置,求助 老规矩 ...

  4. SQL Server 2008导入、导出数据库

    SQL Server 2008数据库的导入.导出和Mysql的导出还有一定的区别,刚开始的时候完全摸不到方向,利用Microsoft SQL Server Management Studio进行导入. ...

  5. Optimal Logging

    by Anthony Vallone How long does it take to find the root cause of a failure in your system? Five mi ...

  6. JS中(function(){xxx})(); 这种写法是什么意思?

    自执行匿名函数: 常见格式:(function() { /* code */ })(); 解释:包围函数(function(){})的第一对括号向脚本返回未命名的函数,随后一对空括号立即执行返回的未命 ...

  7. [03] SQL优化

    1.SQL优化的实质 充分利用索引: 访问尽量少的数据块: 减少表扫描的I/O次数: 尽量避免全表扫描和其他额外开销: 2.oracle数据库常用的两种优化器 RBO(rule-based-optim ...

  8. 我的微软.net演进路线图

    原文地址:我的微软.net演进路线图 我的微软.net演进路线图 我的这几年,编程方面主要是跟在微软旗下奔跑的,主要语言是C# 集成开发环境(IDE) .NET Framework版本 介入年份 Vi ...

  9. PAT_1016 部分A+B

    问题描述: 正整数A的“DA(为1位整数)部分”定义为由A中所有DA组成的新整数PA.例如:给定A = 3862767,DA = 6,则A的“6部分”PA是66,因为A中有2个6. 现给定A.DA.B ...

  10. 263. Ugly Number(C++)

    263. Ugly Number Write a program to check whether a given number is an ugly number. Ugly numbers are ...