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个宝物的位置.如今贼要将全部的宝物拿到手.问最 ...
随机推荐
- Windows Phone 8.1 页面导航
1. Windows Phone 8.1 的应用框架 一个应用拥有 1 个 Window,一个 Window 包含 1 个 Frame,一个 Frame 包含 多个 Page. 获取 Frame 的方 ...
- [OpenXml] Generate excel in memory and dump to file
public static void GenerateExcelFromStream() { using (MemoryStream memoryStream = new MemoryStream() ...
- C# - write values to configuration file
using System.Configuration;System.Configuration.Configuration config = ConfigurationManager.OpenExeC ...
- HttpUnit学习笔记
<!-- htmlUnit --> <dependency> <groupId>net.sourceforge.htmlunit</groupId> & ...
- 普通用户开启AUTOTRACE 功能
AUTOTRACE是一个SQL*Plus工具,用于跟踪SQL的执行计划,收集执行时所耗用资源的统计信息.系统账户本身具有AUTOTRACE,其他账户需要通过手动赋予 一. 用系统账户登录(DBA) S ...
- Ubuntu虚拟机与Window、Arm的通信
Ubuntu虚拟机与Window的通信安装有Ubuntu14.04的虚拟机VMware,将虚拟机的网络适配器配置成NAT类型(默认使用VMnet8进行通信),此时将Ubuntu的IP地址设置成与VMn ...
- JS和JSP的区别
最近很多同学在纠结于名词缩写之间的相似性,因此本人也来写一篇,讲讲JS和JSP的区别. SUN首先发展出SERVLET,其功能比较强劲,体系设计也很先进,只是,它输出HTML语句还是采用了老的CGI方 ...
- fedora 禁止nouveau加载
To remove / disable nouveau drivers from kernel initramfs ## Backup old initramfs nouveau image ## m ...
- mac OS X 10.9.1 配置jdk环境变量
进入命令行 cd ~ touch .bash_profile vi .bash_profile 输入内容jdk变量配置内容: export JAVA_HOME=/Library/Java/JavaVi ...
- StatusStrip状态栏控件
1.ToolStripStatusLabel statusstrip1.Items[].Text="日期"+DateTime.Now.ToString(); Thread p = ...