题目大意:

平面上有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 平面扫描 /// 判断圆的包含关系的更多相关文章

  1. POJ 2932 圆扫描线

    求n个圆中没有被包含的圆.模仿扫描线从左往右扫,到左边界此时如有3个交点,则有3种情况,以此判定该圆是否被离它最近的圆包含,而交点和最近的圆可以用以y高度排序的Set来维护.因此每次到左边界插入该圆, ...

  2. A Round Peg in a Ground Hole - POJ 1584 (判断凸多边形&判断点在多边形内&判断圆在多边形内)

    题目大意:首先给一个圆的半径和圆心,然后给一个多边形的所有点(多边形按照顺时针或者逆时针给的),求,这个多边形是否是凸多边形,如果是凸多边形在判断这个圆是否在这个凸多边形内.   分析:判断凸多边形可 ...

  3. poj 2932 Coneology(扫描线+set)

    Coneology Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 3574   Accepted: 680 Descript ...

  4. Coneology(POJ 2932)

    原题如下: Coneology Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 4937   Accepted: 1086 D ...

  5. 判断圆和矩形是否相交C - Rectangle and Circle

    Description Given a rectangle and a circle in the coordinate system(two edges of the rectangle are p ...

  6. poj 1064 Cable master 判断一个解是否可行 浮点数二分

    poj 1064 Cable master 判断一个解是否可行 浮点数二分 题目链接: http://poj.org/problem?id=1064 思路: 二分答案,floor函数防止四舍五入 代码 ...

  7. HDU 1221 Rectangle and Circle(判断圆和矩形是不是相交)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1221 Rectangle and Circle Time Limit: 2000/1000 MS (J ...

  8. POJ1584 A Round Peg in a Ground Hole 凸包判断 圆和凸包的关系

    POJ1584 题意:给定n条边首尾相连对应的n个点 判断构成的图形是不是凸多边形 然后给一个圆 判断圆是否完全在凸包内(相切也算) 思路:首先运用叉积判断凸多边形 相邻三条边叉积符号相异则必有凹陷 ...

  9. 基于正向扫描的并行区间连接平面扫描算法(IEEE论文)

    作者: Panagiotis Bouros ∗Department of Computer ScienceAarhus University, Denmarkpbour@cs.au.dkNikos M ...

随机推荐

  1. mysql 两张表取总合 和差集

    SELECT id AS kid, NAME, IF (t1.kpi, t1.kpi, 0) AS kpi, t1.sort, STATUS, t1.kpi_idFROMform_kpi_nameLE ...

  2. thinkphp 多语言支持

    ThinkPHP内置多语言支持,如果你的应用涉及到国际化的支持,那么可以定义相关的语言包文件.任何字符串形式的输出,都可以定义语言常量. 要启用多语言功能,需要配置开启多语言行为,在应用的配置目录下面 ...

  3. PHP ftp_site() 函数

    定义和用法 The ftp_site() 函数向 FTP 服务器发送 SITE 命令. SITE 命令没有标准化,在不同的服务器上不尽相同.对于处理文件权限或组关系方面的事情,SITE 命令很有用. ...

  4. 微信H5授权登陆

    Controllerpackage com.iimscloud.auth.provider.controller; import org.springframework.beans.factory.a ...

  5. hexo next主题深度优化(三),引入require.js,适配pjax。

    文章目录 require.js的好处, hexo next中加入require.js 新建一个main.js作为所有js的入口 pjax的require.js实现 关于require js适配过程中报 ...

  6. Codeforces 1167D - Bicolored RBS

    题目链接:http://codeforces.com/problemset/problem/1167/D 题意:题目定义RBS,给你一个字符串,你要对其所有字符染色,使之分解为俩个RBS,使俩个RBS ...

  7. 《Java语言程序设计》编程练习6.18(检测密码)

    6.18 (检测密码)一些网站对于密码具有一些规则.编写一个方法,检测字符串是否是一个有效密码.     假定密码规则如下:     • 密码必须至少8位字符.     • 密码仅能包含字母和数字. ...

  8. OC中Nil nil NULL 和 [NSNULL null]的区别

    关于这个问题看过两三次了,但是每次过两个月脑袋里又会不清晰,索性记录一下加深一下印象. 一.nil 当一个对象置为nil时,这个对象的内存地址就会被系统收回.置空之后是不能进行retain,copy等 ...

  9. 2018-8-10-win10-uwp-如何让一个集合按照需要的顺序进行排序

    title author date CreateTime categories win10 uwp 如何让一个集合按照需要的顺序进行排序 lindexi 2018-08-10 19:16:50 +08 ...

  10. JS事件 失焦事件(onblur)onblur事件与onfocus是相对事件,当光标离开当前获得聚焦对象的时候,触发onblur事件,同时执行被调用的程序。

    失焦事件(onblur) onblur事件与onfocus是相对事件,当光标离开当前获得聚焦对象的时候,触发onblur事件,同时执行被调用的程序. 如下代码, 网页中有用户和密码两个文本框.当前光标 ...