【DFS】Paintball(6-22)
[UVA11853]Paintball
算法入门经典第6章6-22(P175)
题目大意:有一个1000*1000的正方形战场,西南角坐标(0,0),西北角坐标(0,1000),有n个敌人,每个敌人处在(xi,yi),攻击范围为ri,要避开他们的攻击范围,求从最左边出发的最北边出发点及右边的最北边到达点。
试题分析:我们先判断是否能有方案,如何判断?将相交圆的圆心相连,看从交上边界的圆出发是否能到达与下边界相交的圆。然后再这个过程中如果看到与左/右边界相交的圆那么更新答案就好了。
#include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
#include<cmath>
#include<queue>
#include<stack>
#include<algorithm>
using namespace std; inline int read(){
int x=0,f=1;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;
for(;isdigit(c);c=getchar()) x=x*10+c-'0';
return x*f;
}
const int MAXN=2001;
const int INF=999999;
int N,M;
vector<int> vec[MAXN];
struct data{
double x,y,r;
}cir[MAXN];
bool vis[MAXN];
double ansl,ansr;
bool flag=false; double dis(int a,int b){
double x=cir[a].x-cir[b].x;
double y=cir[a].y-cir[b].y;
return sqrt(x*x+y*y);
}
bool DFS(int x){
if(vis[x]||flag) return false;
vis[x]=true;
if(cir[x].x-cir[x].r<=0){
flag=true;
return true;
}
if (cir[x].y<=cir[x].r) ansl=min(ansl,cir[x].x-sqrt(cir[x].r*cir[x].r-cir[x].y*cir[x].y));
if (cir[x].y+cir[x].r>=1000) {
double k=1000-cir[x].y;
ansr=min(ansr,cir[x].x-sqrt(cir[x].r*cir[x].r-k*k));
}
for(int i=0;i<vec[x].size();i++) DFS(vec[x][i]);
return false;
} int main(){
while(scanf("%d",&N)!=EOF){
for(int i=1;i<=N;i++) vec[i].clear();
ansl=ansr=1000.0; flag=false;
for(int i=1;i<=N;i++){
scanf("%lf",&cir[i].y);
scanf("%lf",&cir[i].x);
scanf("%lf",&cir[i].r);
}
for(int i=1;i<N;i++){
for(int j=i+1;j<=N;j++){
if(dis(i,j)<=cir[i].r+cir[j].r){
vec[i].push_back(j);
vec[j].push_back(i);
}
}
}
memset(vis,false,sizeof(vis));
for(int i=1;i<=N;i++)
if(cir[i].r+cir[i].x>=1000)
if(DFS(i)) break;
if(flag) printf("IMPOSSIBLE\n");
else printf("%.2f %.2f %.2f %.2f\n",0.0,ansl,1000.0,ansr);
}
}
【DFS】Paintball(6-22)的更多相关文章
- 【第40套模拟题】【noip2011_mayan】解题报告【map】【数论】【dfs】
		目录:1.潜伏者 [map] 2.Hankson的趣味题[数论]3.mayan游戏[dfs] 题目: 1. 潜伏者(spy.pas/c/cpp)[问题描述]R 国和S 国正陷入战火之中,双方都互派间谍 ... 
- Kattis - glitchbot 【DFS】
		Kattis - glitchbot [DFS] 题意 有一个机器人 刚开始在(0, 0),然后给出一个目标点,并且会给出一系列指令,但是其中会有一个指令是错误的.我们需要找出那个指令,并且改成正确的 ... 
- HDU 6113 度度熊的01世界 【DFS】(2017"百度之星"程序设计大赛 - 初赛(A))
		度度熊的01世界 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ... 
- 【dfs】P1331 海战
		题目描述 在峰会期间,武装部队得处于高度戒备.警察将监视每一条大街,军队将保卫建筑物,领空将布满了F-2003飞机.此外,巡洋船只和舰队将被派去保护海岸线.不幸的是因为种种原因,国防海军部仅有很少的几 ... 
- 【dfs】p1731 生日蛋糕
		1441:[例题2]生日蛋搞 [题目描述] 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体.设从下往上数第i(1≤i≤M)层蛋糕是半径为Ri, 高 ... 
- 【dfs】LETTERS
		1212:LETTERS [题目描述] 给出一个roe×colroe×col的大写字母矩阵,一开始的位置为左上角,你可以向上下左右四个方向移动,并且不能移向曾经经过的字母.问最多可以经过几个字母. [ ... 
- 洛谷P1605 迷宫【dfs】
		题目背景 迷宫 [问题描述] 给定一个N*M方格的迷宫,迷宫里有T处障碍,障碍处不可通过.给定起点坐标和 终点坐标,问: 每个方格最多经过1次,有多少种从起点坐标到终点坐标的方案.在迷宫 中移动有上下 ... 
- 【dfs】BZOJ1703-[Usaco2007 Mar]Ranking the Cows 奶牛排名
		[题目大意] 农夫约翰有N(1≤N≤1000)头奶牛,每一头奶牛都有一个确定的独一无二的正整数产奶率.约翰想要让这些奶牛按产奶率从高到低排序,约翰已经比较了M(1≤M≤10000)对奶牛的产奶率,但他 ... 
- 【DFS】BZOJ3522-[Poi2014]Hotel
		[题目大意] 给出一棵树,求三个节点使得它们两两之间的距离相等,问共有多少种可能性? [思路] 显然,这三个节点是关于一个中心点对称地辐射出去的. 枚举中心点,往它的各个子树跑Dfs.tmp[i]表示 ... 
随机推荐
- Fermat2018游记
			day (-22) 2018年2月5日 Devin大佬给我发了一份Waterloo AIF的原件截图,发现里面居然直接问你的Fermat分数,那么这么重要的考试当然不能错过啊 若干天之后刚开学不久的一 ... 
- hdu 1548 A strange lift (dijkstra算法)
			题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1548 题目大意:升降电梯,先给出n层楼,然后给出起始的位置,即使输出从A楼道B楼的最短时间. 注意的几 ... 
- eclipse+EGIT+GitHub
			下载EGIT:http://wiki.eclipse.org/EGit/FAQ#Where_can_I_find_older_releases_of_EGit.3F 1.下载eclipse版本对应的E ... 
- 9.1docker容器 跨主机连接
			open vswitch 实现跨主机容器连接 准备条件 将本地的网卡 与新建的网桥建立连接 配置 docker 启动项 weave实现跨主机容器连接 null 
- 一个文档让vim飞起来
			原文地址:http://www.cnblogs.com/songfy/p/5635757.html 引言 今天我们特地来讲讲这个vim的配置. vim这东西, 很多人装逼的时候经常会提到, 不过大部分 ... 
- 访问dubbo没有权限,通过ip进行跳转服务器,并通过有权限服务器代理访问
			#启动ip跳转 echo 1 > /proc/sys/net/ipv4/ip_forward vi /etc/sysctl.conf net.ipv4.ip_forward =1 sysctl ... 
- MUI 页面刷新及页面传值问题
			一.页面刷新问题 1.父页面A跳转到子页面B,B页面修改数据后再跳回A页面,刷新A页面数据 (1).父页面A代码 window.addEventListener("pageflowrefre ... 
- node中--save跟--save--dev
			--save参数表示将该模块写入dependencies属性, --save-dev表示将该模块写入devDependencies属性. dependencies字段指定了项目运行所依赖的模, d ... 
- 《逐梦旅程 WINDOWS游戏编程之从零开始》笔记2——透明贴图,动画技术
			第5章 透明贴图 像这样直接贴图会产生这种情况,所以我们需要透明贴图. 透明遮罩法:主要利用BitBlt函数中Raser(光栅)值的运算,需要准备素材图和遮罩图: 这个方法的原理解释见书131页. 示 ... 
- hive的窗口函数1
			Hive中提供了越来越多的分析函数,用于完成负责的统计分析.抽时间将所有的分析窗口函数理一遍,将陆续发布.今天先看几个基础的,SUM.AVG.MIN.MAX.用于实现分组内所有和连续累积的统计. 1. ... 
