hdu 4454 Stealing a Cake 三分法
很容易想到三分法求解,不过要分别在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 三分法的更多相关文章
- 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(三分法)
给定一个起始点,一个矩形,一个圆,三者互不相交.求从起始点->圆->矩形的最短距离. 自己画一画就知道距离和会是凹函数,不过不是一个凹函数.按与水平向量夹角为圆心角求圆上某点坐标,[0, ...
- HDU 4454 Stealing a Cake(枚举角度)
题目链接 去年杭州现场赛的神题..枚举角度..精度也不用注意.. #include <iostream> #include <cstdio> #include <cstr ...
- HDU 4454 Stealing a Cake --枚举
题意: 给一个点,一个圆,一个矩形, 求一条折线,从点出发,到圆,再到矩形的最短距离. 解法: 因为答案要求输出两位小数即可,精确度要求不是很高,于是可以试着爆一发,暴力角度得到圆上的点,然后求个距离 ...
- hdu 4454 Stealing a Cake
简单的计算几何: 可以把0-2*pi分成几千份,然后找出最小的: 也可以用三分: #include<cstdio> #include<cmath> #include<al ...
- HDU 4454 - Stealing a Cake(三分)
我比较快速的想到了三分,但是我是从0到2*pi区间进行三分,并且漏了一种点到边距离的情况,一直WA了好几次 后来画了下图才发现,0到2*pi区间内是有两个极值的,每个半圆存在一个极值 以下是代码 #i ...
- hdu 4454 Stealing a Cake(计算几何:最短距离、枚举/三分)
题意:已知起点.圆.矩形,要求计算从起点开始,经过圆(和圆上任一点接触即可),到达矩形的路径的最短距离.(可以穿过园). 分析:没什么好的方法,凭感觉圆上的每个点对应最短距离,应该是一个凸函数,用三分 ...
- hdu 4771 Stealing Harry Potter's Precious(bfs)
题目链接:hdu 4771 Stealing Harry Potter's Precious 题目大意:在一个N*M的银行里,贼的位置在'@',如今给出n个宝物的位置.如今贼要将全部的宝物拿到手.问最 ...
随机推荐
- 谷歌(Chrome)安装Advanced REST Client插件
进入Extensions(工具——>扩展程序) 点击Get More extensions或新建标签页点击网上应用店 如果加载太慢,出现chrome网上应用店无法打开,显示暂时无法加载该应用的画 ...
- iOS动画——弹窗动画(pop动画)
用pop动画简单实现弹窗的缩放和渐变,感觉这个动画常用,就写一下博客 pop动画是Facebook推出的动画引擎,请自行到GitHub上搜索下载拖拽导入xcode项目中. 更多pop动画使用和原理可网 ...
- 自定义TREEVIEW UL无限极嵌套
背景:做一个多级图片分类管理,当然要用到TreeView,在asp.net中已经提供了此服务器控件,参照效果,自定义一个简单可控性高的就当做练手吧! 效果:如图,小图标 折叠 展开 ico-tr ...
- Android Studio生成APK自动追加版本号
转载说明 本篇文章可能已经更新,最新文章请转:http://www.sollyu.com/android-apk-studio-generated-automatically-appends-a-ve ...
- C/C++易错小记录
一:对字符串的 strlen() 与 sizeof #include <string.h> #include <stdio.h> int main(void) { char* ...
- ThinkPHP3.2 加载过程(二)
回顾: 上次介绍了 ThinkPHP 的 Index.PHP入口文件.但只是TP的入口前面的入口(刷boss总是要过好几关才能让你看到 ,不然boss都没面子啊),从Index.PHP最后一行把我们引 ...
- 使用MySQL数据库将汉字转换成拼音的一个C语言小程序
环境: mysql:mysql-5.1.65 centos:centos 6.5 编译命令: gcc -o chinesetopinyin chinesetopinyin.c -L/usr/lib/m ...
- Java中的队列:java.util.Queue接口
队列是一种特殊的线性表,它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作. Queue接口与List.Set同一级别,都是继承了Collection接口.Linked ...
- Linux 下添加普通用户,登陆并删除
adduser 命令.LINUX创建用户的命令useradd -g test -d /home/test1 -s /etc/bash -m test1注解:-g 所属组 -d 家目录 -s 所用的SH ...
- ASP.NET 将DataTable解析成JSON简介
这里解析json使用的是Newtonsoft.Json.dll程序集.下面请看code: using System; using System.Collections.Generic; using S ...