Cod sursa(job #41019)

Utilizator skyelHighScore skyel Data 27 martie 2007 21:46:06
Problema Regiuni Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.06 kb
#include <fstream.h>   
#define input "regiuni.in"
#define output "regiuni.out"
#define Nmax 1001
#define Mmax 1001

//using namespace std;

int main()
	{
	ifstream fin(input);
	ofstream fout(output);
   long sec[Mmax][Mmax/30],n,m,z,j,s,q;
   int i,k,ok,t,a[Mmax],b[Mmax],c[Mmax],dx[Nmax],dy[Nmax],h;
   fin>>n>>m;
	k=0;
	for (i=0;i<n;i++)
	    {
       fin>>a[i]>>b[i]>>c[i];
       }
	for (i=0;i<m;i++)
       {
       fin>>dx[i]>>dy[i];
       }

   for(i=0,h=0;i<m;i++,h++)
		{
		for(j=0;j<n;j++)
			{
			if (j%30==0)
				{
				sec[i][j/30]=z;
				z=0;
				}
			s=dx[i]*a[j]+dy[i]*b[j]+c[j];
			if(a[j]*b[j]!=0)
				{
				if(s>0)
					z+=1<<(j%30);
				}
			else
				{
				if(s<0)
					z+=1<<(j%30);
				}
			}
		sec[i][(n/30)+1]=z;
		z=0;
		ok=1;
      for (t=0;t<i;t++)
			 {
			 if (!memcmp(sec[i], sec[t], (n/30)+1)   )
             {
             ok=0;
             h--;
             break;
             }
          }     
      if (ok)
         k++;                        
      }
   fout<<k<<"\n";
	return 0;
	}