hdu 4454 Stealing a Cake
简单的计算几何;
可以把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的更多相关文章
- hdu 4454 Stealing a Cake(三分之二)
pid=4454" target="_blank" style="">题目链接:hdu 4454 Stealing a Cake 题目大意:给定 ...
- hdu 4454 Stealing a Cake (三分)
Stealing a Cake Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- HDU 4454 Stealing a Cake(枚举角度)
题目链接 去年杭州现场赛的神题..枚举角度..精度也不用注意.. #include <iostream> #include <cstdio> #include <cstr ...
- HDU 4454 Stealing a Cake --枚举
题意: 给一个点,一个圆,一个矩形, 求一条折线,从点出发,到圆,再到矩形的最短距离. 解法: 因为答案要求输出两位小数即可,精确度要求不是很高,于是可以试着爆一发,暴力角度得到圆上的点,然后求个距离 ...
- hdu 4454 Stealing a Cake 三分法
很容易想到三分法求解,不过要分别在0-pi,pi-2pi进行三分. 另外也可以直接暴力枚举…… 代码如下: #include<iostream> #include<stdio.h&g ...
- HDU 4454 - Stealing a Cake(三分)
我比较快速的想到了三分,但是我是从0到2*pi区间进行三分,并且漏了一种点到边距离的情况,一直WA了好几次 后来画了下图才发现,0到2*pi区间内是有两个极值的,每个半圆存在一个极值 以下是代码 #i ...
- hdu 4454 Stealing a Cake(三分法)
给定一个起始点,一个矩形,一个圆,三者互不相交.求从起始点->圆->矩形的最短距离. 自己画一画就知道距离和会是凹函数,不过不是一个凹函数.按与水平向量夹角为圆心角求圆上某点坐标,[0, ...
- hdu 4454 Stealing a Cake(计算几何:最短距离、枚举/三分)
题意:已知起点.圆.矩形,要求计算从起点开始,经过圆(和圆上任一点接触即可),到达矩形的路径的最短距离.(可以穿过园). 分析:没什么好的方法,凭感觉圆上的每个点对应最短距离,应该是一个凸函数,用三分 ...
- hdu 4771 Stealing Harry Potter's Precious(bfs)
题目链接:hdu 4771 Stealing Harry Potter's Precious 题目大意:在一个N*M的银行里,贼的位置在'@',如今给出n个宝物的位置.如今贼要将全部的宝物拿到手.问最 ...
随机推荐
- java float、double精度研究(转)
在java中运行一下代码System.out.println(2.00-1.10);输出的结果是:0.8999999999999999很奇怪,并不是我们想要的值0.9 再运行如下代码:System.o ...
- 安卓UI美化_drawable
UI美化 drawable资源 ------------------------------------------state drawable资源在不同状态下显示不同的图片在<selector ...
- 深入理解计算机系统第二版习题解答CSAPP 2.1
A.将0x39A7F8转换为二进制. 0011 1001 1010 0111 1111 1000 B.将二进制1100 1001 0111 1011转换为十六进制. 0xC97B C.将0xD5E ...
- Maven笔记(二)仓库
1.仓库布局 任何一个构件都有其唯一的坐标,根据这个坐标可以定义其在仓库中的唯一存储路径,这就是Maven的仓库布局方式 路径与坐标的对应关系为:groupId/artifactId/version/ ...
- C#微信公众号开发 -- (七)自定义菜单事件之VIEW及网页(OAuth2.0)授权
通俗来讲VIEW其实就是我们在C#中常用的a标签,可以直接在自定义菜单URL的属性里面写上需要跳转的链接,也即为单纯的跳转. 但更多的情况下,我们是想通过VIEW来进入指定的页面并进行操作. 举一个简 ...
- PAT_1072 Gas Station
1072. Gas Station (30) 时间限制 200 ms 内存限制 32000 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue ...
- 小技巧之指定refer
在当前页面A的控制台输入window.location.href='要跳去的页面B',B页面的refer即为A页面.
- 学习笔记_Java get和post区别(转载_GET一般用于获取/查询资源信息,而POST一般用于更新资源信息)
转载自:[hyddd(http://www.cnblogs.com/hyddd/)] 总结一下, Get是向服务器发索取数据的一种请求 而Post是向服务器提交数据的一种请求,在F ...
- php导出execl
<?php function export_excel($items,$fields,$fields_array,$name) { /* * 调用方法示例 * $items = $this-&g ...
- Cordova5 -- iOS实战(一)
由于最近公司的项目要求用Cordova来进行开发,便开始了对Cordova的学习.由于本人之前也是做iOS开发,因此相关内容主要从iOS平台的角度来写.刚开始学习Cordova这个平台,希望以此总 ...