POJ 2932 平面扫描 /// 判断圆的包含关系
题目大意:
平面上有n个两两不相交的圆,给定圆的圆心(x,y)和半径 r
求所有最外层的 即 不包含于其他圆内部的圆
挑战258页 平面扫描
记录所有圆的左端和右端 排序后 逐一扫描
将到当前圆为止的最外层的圆存入数组
当遇到一个圆的左端
判断 这个圆 是否被 离它最近的上下的两个已存入的最外层的圆 包含
若被包含 则跳过该圆
若未被包含 说明其是一个最外层的圆 存入数组
这里不会有 它包含上下其中某个圆 的情况出现
因为包含某个圆 那么 该圆的左端 必定位于 被包含圆的左端的左边
但是平面扫描限制了 该圆的左端必定位于 已知的最外层的圆的左端的右边
#include <cstdio>
#include <algorithm>
#include <string.h>
#include <set>
#include <vector>
#define F first
#define S second
#define P pair<double,int>
using namespace std;
const int N=+;
double x[N],y[N],r[N];
/*圆i是否包含在圆j内
dx*dx+dy*dy 两圆圆心距 的平方
若小于圆j的半径的平方
则i包含于j内
这里的前提是所有圆两两不相交
*/
bool inside(int i,int j)
{
double dx=x[j]-x[i], dy=y[j]-y[i];
return dx*dx+dy*dy<=r[j]*r[j];
}
int main()
{
vector <P> vec;
int n; scanf("%d",&n);
for(int i=;i<n;i++) {
scanf("%lf%lf%lf",&r[i],&x[i],&y[i]);
vec.push_back(P(x[i]-r[i],i)); // 左端
vec.push_back(P(x[i]+r[i],i+n)); // 右端 i+n便于和左端点区别开
}
sort(vec.begin(),vec.end());
set <P> s;
vector <int> ans;
for(int i=;i<vec.size();i++) {
int id=vec[i].S;
if(id<n) { // 左端点
set <P> ::iterator it=s.lower_bound(P(y[id],id));
// 找到id上面的圆
if(it!=s.end() && inside(id,it->S)) continue;
// 判断上面的圆有没有包含id
if(it!=s.begin() && inside(id,(--it)->S)) continue;
// 判断下面的圆有没有包含id
ans.push_back(id);
s.insert(P(y[id],id));
}
else s.erase(P(y[id%n],id%n)); // 右端点
// 之后出现的圆不可能于该圆有任何包含关系 将该圆去掉
}
sort(ans.begin(),ans.end());
printf("%d\n",ans.size());
for(int i=;i<ans.size();i++)
printf("%d ",ans[i]+);
printf("\n");
return ;
}
POJ 2932 平面扫描 /// 判断圆的包含关系的更多相关文章
- POJ 2932 圆扫描线
求n个圆中没有被包含的圆.模仿扫描线从左往右扫,到左边界此时如有3个交点,则有3种情况,以此判定该圆是否被离它最近的圆包含,而交点和最近的圆可以用以y高度排序的Set来维护.因此每次到左边界插入该圆, ...
- A Round Peg in a Ground Hole - POJ 1584 (判断凸多边形&判断点在多边形内&判断圆在多边形内)
题目大意:首先给一个圆的半径和圆心,然后给一个多边形的所有点(多边形按照顺时针或者逆时针给的),求,这个多边形是否是凸多边形,如果是凸多边形在判断这个圆是否在这个凸多边形内. 分析:判断凸多边形可 ...
- poj 2932 Coneology(扫描线+set)
Coneology Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 3574 Accepted: 680 Descript ...
- Coneology(POJ 2932)
原题如下: Coneology Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 4937 Accepted: 1086 D ...
- 判断圆和矩形是否相交C - Rectangle and Circle
Description Given a rectangle and a circle in the coordinate system(two edges of the rectangle are p ...
- poj 1064 Cable master 判断一个解是否可行 浮点数二分
poj 1064 Cable master 判断一个解是否可行 浮点数二分 题目链接: http://poj.org/problem?id=1064 思路: 二分答案,floor函数防止四舍五入 代码 ...
- HDU 1221 Rectangle and Circle(判断圆和矩形是不是相交)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1221 Rectangle and Circle Time Limit: 2000/1000 MS (J ...
- POJ1584 A Round Peg in a Ground Hole 凸包判断 圆和凸包的关系
POJ1584 题意:给定n条边首尾相连对应的n个点 判断构成的图形是不是凸多边形 然后给一个圆 判断圆是否完全在凸包内(相切也算) 思路:首先运用叉积判断凸多边形 相邻三条边叉积符号相异则必有凹陷 ...
- 基于正向扫描的并行区间连接平面扫描算法(IEEE论文)
作者: Panagiotis Bouros ∗Department of Computer ScienceAarhus University, Denmarkpbour@cs.au.dkNikos M ...
随机推荐
- delphi Treeview用法
Treeview用于显示按照树形结构进行组织的数据. Treeview控件中一个树形图由节点(TreeNode)和连接线组成.TtreeNode是TTreeview的基本组成单元. ...
- NX二次开发-将信息窗口中的文本保存到文本文件中UF_UI_save_listing_window
#include <uf.h> #include <uf_ui.h> UF_initialize(); //打开信息窗口 UF_UI_open_listing_window() ...
- Android中滑屏实现----触摸滑屏以及Scroller类详解 .
转:http://blog.csdn.net/qinjuning/article/details/7419207 知识点一: 关于scrollTo()和scrollBy()以及偏移坐标的设置/取值问 ...
- Excel的数据分析—排位与百分比
Excel的数据分析-排位与百分比 某班级期中考试进行后,按照要求仅公布成绩,但学生及家长要求知道排名.故欲公布成绩排名,学生可以通过成绩查询到自己的排名,并同时得到该成绩位于班级百分比排名(即该同学 ...
- Oracle 生成sys_guid
select sys_guid() from dual;select sys_guid() from dual connect by rownum<100
- nodejs--express安装失败的原因
1.检查更新所有的npm ,jade,或者ejs. 2.在用jade或ejs也是有区别的,jade适合个人秀,ejs更实用与商务. 3.express在4.+之后的版本都分离了,推荐用3.+的版本稳定 ...
- elasticsearch的基本用法(转载)
本文出自:http://blog.csdn.net/feelig/article/details/8499614 最大的特点: 1. 数据库的 database, 就是 index 2. 数据库 ...
- 2018-10-29-微软-Tech-Summit-技术暨生态大会课程-·-基于-Roslyn-打造高性能预编译框架...
title author date CreateTime categories 微软 Tech Summit 技术暨生态大会课程 · 基于 Roslyn 打造高性能预编译框架 lindexi 2018 ...
- Spring Boot 成长之路(一) 快速上手
1.创建工程 利用IntelliJ IDEA新建一个Spring Boot项目的Web工程 2.查看初始化的spring boot项目 工程建好之后会出现如下的目录结构: 值得注意的第一件事是,整个项 ...
- 阿里云宣布 Serverless 容器服务 弹性容器实例 ECI 正式商业化
摘要: 阿里云宣布弹性容器实例 ECI(Elastic Container Instance)正式商业化,ECI 是阿里云践行普惠的云计算理念,将 Serverless 和 Container 技术结 ...