POJ

来源:互联网 发布:com用来表示什么域名 编辑:程序博客网 时间:2024/06/16 14:38

给出n条线段把一个区域分割成不同的地区,之后给你m个点,求每个地区有几个点。

线段是从左到右给出的,所以不用做什么处理。

对于每一个点我们直接二分,即可。


#include<cstdio>
#include<cstdlib>
#include<cstring>
using namespace std;
struct point{
int x,y;
};
struct Node{
point a,b;
}A[5010];
int pos[5010];
int judge(int xx,int yy,int mid){
int ans=(A[mid].a.x-xx)*(A[mid].b.y-yy)-(A[mid].a.y-yy)*(A[mid].b.x-xx);
return ans;
}
void search(int xx,int yy,int n){
int left=0,right=n-1;
while(left<=right){
int mid=(left+right)>>1;
if(judge(xx,yy,mid)>=0){
left=mid+1;
}
else {
right=mid-1;
}
}
pos[left]++;
}
int main()
{
int n,m,i,j,x1,x2,y1,y2;
while(scanf("%d",&n),n){
scanf("%d%d%d%d%d",&m,&x1,&y1,&x2,&y2);
for(i=0;i<n;++i){
int xd,xu;
scanf("%d%d",&xu,&xd);
A[i].a.x=xu;
A[i].a.y=y1;
A[i].b.x=xd;
A[i].b.y=y2;
}
memset(pos,0,sizeof(pos));
for(i=0;i<m;++i){
int xx,yy;
scanf("%d%d",&xx,&yy);
search(xx,yy,n);
}
for(i=0;i<=n;++i){
printf("%d: %d\n",i,pos[i]);
}
printf("\n");
}
return 0;
}
原创粉丝点击