首页 > 代码库 > UVALive 6263 The Dragon and the knights --统计,直线分平面
UVALive 6263 The Dragon and the knights --统计,直线分平面
题意:给n条直线,将一个平面分成很多个部分,再给m个骑士的坐标,在一个部分内只要有一个骑士即可保护该部分,问给出的m个骑士是不是保护了所有部分。
解法:计算每个骑士与每条直线的位置关系(上面还是下面),用0,1表示,所以每个骑士会有一个01串,最后统计出这n条直线分成的部分数(可能有平行的),然后排序每个骑士的01串,看有多少个处在不同部分的骑士(01串不同的个数),然后比较个数关系,得出答案。
代码:
#include <iostream>#include <cstdio>#include <cstring>#include <cmath>#include <algorithm>#include <string>#define ll long longusing namespace std;#define N 50007struct Line{ int A,B,C;}line[107];bool UPLine(Line ka,ll x,ll y){ ll res = ka.A*x + ka.B*y + ka.C; return res > 0;}bool intersection(Line ka,Line kb){ if(ka.A*kb.B == ka.B*kb.A) return false; return true;}string ss[N];int main(){ int t,n,m,i,j; int x,y; scanf("%d",&t); while(t--) { scanf("%d%d",&n,&m); for(i=0;i<n;i++) scanf("%d%d%d",&line[i].A,&line[i].B,&line[i].C); string tmp = ""; for(i=0;i<n;i++) tmp += "0"; for(i=0;i<m;i++) { scanf("%d%d",&x,&y); ss[i] = tmp; for(j=0;j<n;j++) { if(UPLine(line[j],x,y)) ss[i][j] = ‘1‘; } } int C = n+1; for(i=0;i<n;i++) { for(j=i+1;j<n;j++) if(intersection(line[i],line[j])) C++; } sort(ss,ss+m); int cnt = 1; for(i=1;i<m;i++) { if(ss[i] != ss[i-1]) cnt++; } if(cnt >= C) puts("PROTECTED"); else puts("VULNERABLE"); } return 0;}
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。