#include <stdio.h> #include <string.h> #include <stdlib.h> #include <limits.h> #include <malloc.h> #include <ctype.h> #include <math.h> #include <string> #include<iostream> #include <algorithm> using namespace std; #define MAXN 11111 #include <queue> #include <vector> struct node { int x, y; }q[66666]; void work(int a,int b) { int ans=0; int x=130,y=130,lon=1; while(ans<=65555) { for(int i=0; i<lon; i++)//zuo { if((x-130)*a+b==y-130) { x--; continue; } q[ans].x=x--; q[ans++].y=y; // printf("%d\n",cost[y][x+1]); } for(int i=0; i<lon; i++)//shang { if((x-130)*a+b==y-130) { y++; continue; } q[ans].x=x; q[ans++].y=y++; // printf("%d\n",cost[y-1][x]); } lon++; for(int i=0; i<lon; i++)//you { if((x-130)*a+b==y-130) { x++; continue; } q[ans].x=x++; q[ans++].y=y; // printf("%d\n",cost[y][x-1]); } for(int i=0; i<lon; i++)//xia { if((x-130)*a+b==y-130) { y--; continue; } q[ans].x=x; q[ans++].y=y--; // printf("%d\n",cost[y+1][x]); } lon++; } } int main() { int a,b,k,t,cas=1; // freopen("in.txt","r",stdin); scanf("%d",&t); while(t--) { scanf("%d%d",&a,&b); work(a,b); for(int i=0;i<=65555;i++) q[i].x-=130,q[i].y-=130; scanf("%d",&k); printf("Caso %d\n",cas++); for(int i=0; i<k; i++) { int sum1=0,c,d; scanf("%d%d",&c,&d); if(q[c].x*a+b>q[c].y&&q[d].x*a+b>q[d].y) sum1=1; else if(q[c].x*a+b<q[c].y&&q[d].x*a+b<q[d].y) sum1=1; else sum1=0; if(sum1) printf("Mesmo lado da fronteira\n"); else printf("Lados opostos da fronteira\n"); } } return 0; }
POJ 3119 Friends or Enemies?,布布扣,bubuko.com
原文:http://blog.csdn.net/kewowlo/article/details/38351263