2017 Multi-University Training Contest - Team 9 1003&&HDU 6163 CSGO【计算几何】
CSGO
Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 127 Accepted Submission(s): 20

Senior
Pan is crazy about CSGO and she is so skilled. She can kill every enemy
she spots at the same time, even if they are in different positions.
There
are some walls in a map. The locations of enemies are represented by
some points and walls are represented by some line segments in the XY
plane. The position of senior Pan is also described as a point. Senior
Pan can spot an enemy if and only if the segment between them doesn’t
intersect with any wall segment. But if there are other enemies on this
segment, she can kill all of them.
For some given positions, senior
Pan wants to know how many enemies she can kill in these positions. Your
Task is to write a program to figure it out.
∙
The first line contains three integers N, M, Q representing
respectively the number of enemies, the number of walls and the number
of positions senior Pan chooses. For the next N lines, each line contain
two integers X and Y, indicating the location of enemies is (X, Y). The
next M lines, each line contain four integers X1, Y1, X2, Y2,
indicating two endpoints of the wall are (X1, Y1) and (X2, Y2). The last
Q lines, each line contain two integers X and Y, indicating the
location of senior Pan chooses is (X, Y).
∙
You can assume that walls don’t intersect even if in their endpoints,
no enemies have the same location and no enemies are in walls.
∙ N, M <= 10 ^ 4.
∙ Q <= 12.
∙ -10 ^ 6 <= X, Y, X1, Y1, X2, Y2 <= 10 ^ 6
For
next Q lines, each line output a number which represents the number of
enemies senior Pan can kill in her i-th chosen location.
3 2 1
1 1
2 2
-1 1
0 1 -1 0
2 -2 2 0
0 0
5 4 2
29 -8
19 33
-46 -44
-38 19
9 -20
40 45 38 18
9 -32 -8 46
33 20 35 -19
22 17 -5 40
19 -38
-17 -21
Case #1:
2
Case #2:
3
2
平面上有一些点和一些线段,保证这些线段互不相交,点不在线段上。
每次问从一个点能看到多少个点。一个点能看到另一点当且仅当这两点连线的线段不和任何一个已知的线段相交。(这里的相交均指非规范相交)
每次以询问点为极点极角排序。线段两端点拆成两个事件,一次出现,一次消失。对于枚举的某一个角度,能否看见当前角度的点仅取决于当前角度上离极点最近的线段,由于保证线段不相交,一条线段在插入时和还存在线段的相对位置是不会改变的,所以可以用set维护,每次先处理当前角度上所有的点是否被线段遮挡就可以了。
+ M)log(N + M))。
#include<bits/stdc++.h> using namespace std;
const int N = ;
const double eps = 1e-;
const double pi = acos(-1.0);
typedef complex<double> Point; double Det(const Point & a, const Point & b) {return (conj(a) * b).imag();}
double Dot(const Point & a, const Point & b) {return (conj(a) * b).real();}
int sgn(double x) {if(fabs(x) < eps) return ; if(x > eps) return ; return -;} double _ang;
Point ori = (Point) {, };
struct Line :public vector<Point>{
double k;
Line(){}
Line(Point a, Point b){
push_back(a), push_back(b);
k = atan2((b - a).imag(), (b - a).real());
}
};
Point Vec(Line a) {return a[] - a[];}
Point LineIntersection(const Line & a, const Line & b){
double k1 = Det(Vec(a), Vec(b));
double k2 = Det(Vec(b), a[] - b[]);
if(!sgn(k1)){
if(sgn(abs(a[] - b[]) - abs(a[] - b[])) > ) return a[];
else return a[];
}
return a[] + Vec(a) * k2 / k1;
} bool operator < (const Line & a, const Line & b){
Line cur = (Line) {ori, (Point) {cos(_ang), sin(_ang)}};
if(sgn(abs(LineIntersection(a, cur)) - abs(LineIntersection(b, cur))) < ) return ;
return ;
} struct Event{
double k;
int id, typ;
bool operator < (const Event & a) const{
if(sgn(k - a.k)) return k < a.k;
return typ < a.typ;
}
}; double CalcAng(const Point & a) {return atan2(a.imag(), a.real());}
Point p[N];
Line w[N], seg[N];
Event e[N << ]; int q, n, m, tot;
set<Line> s;
int rec[N]; int Calc(int x){
tot = ;
s.clear();
for(int i = ; i <= n; i ++)
e[++ tot] = (Event){CalcAng(p[i] - p[x]), i, }; bool flag = ;
for(int i = ; i <= m; i++){
seg[i] = (Line) {w[i][] - p[x], w[i][] - p[x]};
if(sgn(CalcAng(seg[i][]) - CalcAng(seg[i][])) > ) swap(seg[i][], seg[i][]);
flag = ;
if(sgn(Det(Vec(seg[i]), Point(-, ))) != && sgn(abs(CalcAng(seg[i][]) - CalcAng(seg[i][])) - pi) > ) flag = ;
if(flag) e[++ tot] = (Event) {CalcAng(seg[i][]), i, }, e[++tot] = (Event) {CalcAng(seg[i][]), i, };
else{
e[++ tot] = (Event) {-pi, i, };
e[++ tot] = (Event) {CalcAng(seg[i][]), i, };
e[++ tot] = (Event) {CalcAng(seg[i][]), i, };
e[++ tot] = (Event) {pi, i, };
}
} sort(e + , e + tot + );
int cnt = ;
Point dir, dd;
Line t;
for(int i = ; i <= tot; i ++){
_ang = e[i].k;
if(e[i].typ & ){
dir = (Point) {cos(_ang), sin(_ang)};
if(s.empty() || sgn(abs(LineIntersection(*s.begin(), (Line) {ori, dir})) - abs(p[e[i].id] - p[x])) > ){
cnt ++, rec[cnt] = e[i].id;
}
}
else if(!e[i].typ) s.insert(seg[e[i].id]);
else s.erase(seg[e[i].id]);
} return cnt;
} int Tcase; char fi[] = "pcx.in", fo[] = "pcx.ans";
void Solve(){
printf("Case #%d:\n", ++ Tcase);
double x, y;
Point a, b;
for(int i = ; i <= n; i ++){
scanf("%lf%lf", &x, &y);
p[i] = (Point) {x, y};
}
for(int i = ; i <= m; i ++){
scanf("%lf%lf", &x, &y);
a = (Point) {x, y};
scanf("%lf%lf", &x, &y);
b = (Point) {x, y};
w[i] = (Line) {a, b};
} int ans;
for(int i = ; i <= q; i ++){
scanf("%lf%lf", &x, &y);
p[n + ] = (Point) {x, y};
ans = Calc(n + );
printf("%d\n", ans);
} return;
} int main(){
// freopen("_pc.in", "r", stdin);
// freopen("_pc.ans", "w", stdout);
while(~scanf("%d%d%d", &n, &m, &q))
Solve();
//printf("--->%lf\n", (double) clock() / CLOCKS_PER_SEC);
return ;
}
2017 Multi-University Training Contest - Team 9 1003&&HDU 6163 CSGO【计算几何】的更多相关文章
- 2017 Multi-University Training Contest - Team 1 1003&&HDU 6035 Colorful Tree【树形dp】
Colorful Tree Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)T ...
- 2017 Multi-University Training Contest - Team 9 1005&&HDU 6165 FFF at Valentine【强联通缩点+拓扑排序】
FFF at Valentine Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
- 2017 Multi-University Training Contest - Team 9 1004&&HDU 6164 Dying Light【数学+模拟】
Dying Light Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Tot ...
- 2017 Multi-University Training Contest - Team 9 1002&&HDU 6162 Ch’s gift【树链部分+线段树】
Ch’s gift Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total S ...
- 2017 Multi-University Training Contest - Team 9 1001&&HDU 6161 Big binary tree【树形dp+hash】
Big binary tree Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
- 2017 Multi-University Training Contest - Team 1 1006&&HDU 6038 Function【DFS+数论】
Function Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total ...
- 2017 Multi-University Training Contest - Team 1 1002&&HDU 6034 Balala Power!【字符串,贪心+排序】
Balala Power! Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)T ...
- 2017 Multi-University Training Contest - Team 1 1011&&HDU 6043 KazaQ's Socks【规律题,数学,水】
KazaQ's Socks Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)T ...
- 2017 Multi-University Training Contest - Team 1 1001&&HDU 6033 Add More Zero【签到题,数学,水】
Add More Zero Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)T ...
随机推荐
- 为什么在有的服务器上禅道、蝉知安装会报错? 之理解MySQL的SQL_MODE
最近用蝉知的CMS 建站比较多,感觉蛮顺手的,但在给客户安装的时候却会出现安装报错,其原因也很简单 查看了一下他们的install.sql文件中,有些时间字段的默认值是0000-00-00 00:00 ...
- Docker(八):Docker端口映射
1.随机映射 docker run -P -d --name mynginx1 nginx [root@node1 ~]# docker ps -l CONTAINER ID IMAGE COMMAN ...
- ES6 Proxy和Reflect (上)
Proxy概述 Proxy用于修改某些操作的默认行为,等同于在语言层面做出修改,所以属于一种"元编程"(meta programming),即对编程语言进行编程. Proxy可以理 ...
- ADG监控
cx_Oracle环境配置 export ORACLE_BASE=/u01/app/oracle export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1 ...
- 学习时用的软件最新 开发环境为Visual Studio 2010,数据库为SQLServer2005,使用.net 4.0开发。 超市管理系统
一.源码特点 1.采用典型的三层架构进行开发.模板分离,支持生成静态 伪静态..购物车.登陆验证.div+css.js等技术二.功能介绍 1.本源码是一个超市在线购物商城源码,该网上商城是给超市便利店 ...
- JavaBean转Map方法
Map<String, Object> fieldMap =new HashMap<String, Object>(); BeanInfo beanInfo = Introsp ...
- jamup与gb2i组合
软件一定要开嗓单效果器,最好不要关闭中断软件/声音,每次有重新检测电流必须会有嗓音,最好用ipad ,不然会烦死人.默认delay太长,在DLY面板修改 gb2i 效果还行,他的价值重在使用,让新人使 ...
- Mac说——关闭SIP
今天在安装keras的时候总是提示numpy无法安装,百度了下,说是新版本的os系统加入了spi机制. 什么是SIP: 系统集成保护(System Integrity Protection,SIP), ...
- js 对象的值传递
一.变量赋值的不同 1.原始值 在将一个保存着原始值的变量复制给另一个变量时,会将原始值的副本赋值给新变量,此后这两个变量是完全独立的. 2.引用值: 在将一个保存着对象内存地址的变量复制给另一个变量 ...
- QtCreator 断点不起作用
使用QtCreator 调试程序时一直无法进入断点,断点根本不起作用. 解决方法: 打开.pro文件 将图中的release改为debug,再次调试运行就可以进入断点了.