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;
}
阅读全文
0 0
- POJ
- poj
- POJ
- POJ
- poj
- poj
- POJ
- POJ
- poj
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- POJ
- luogu3933 Chtholly Nota Seniorious(二分答案+贪心)
- 要做好脑机接口技术,马斯克和扎克伯格还差一本“菜谱”
- Java 一阶线性包络谱算法
- 罗永浩评苹果抽取30%打赏费:傻X似的流氓,迟早被抵制
- HTTP Servlet基础
- POJ
- android中handler消息发送机制源码剖析
- Sturts2放值
- 选课
- 【poj 1061】 青蛙的约会
- 一季度共 34 家 AI 创业公司被收购,谷歌和苹果是购买主力
- Unity抛物线动画
- COMOUTEX 2017开展在即 打造多元化科技盛宴
- KMP算法(next回退分析)