Cod sursa(job #39041)

Utilizator ctesctes tesc ctes Data 26 martie 2007 13:07:55
Problema Regiuni Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.19 kb
#include<string.h>
#include<fstream.h>
#define input "regiuni.in"
#define output "regiuni.out"
#define Nmax 1005
#define Mmax 1005

//using namespace std;

long int sec[Mmax][Mmax],n,m,z;

int cmp(long x[Mmax],long y[Mmax])
    {
    int i;
    for (i=0;i<n/30;i++)
        {
        if (x[i]!=y[i])
           return 1;
        }
    return 0;                  
    }

int main()
	{
	ifstream fin(input);
	ofstream fout(output);
	int i,k,s,ok,t;
	long j;
   int 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;i<m;i++)
		{
		for(j=0;j<n;j++)
			{
			if (j%31==0)
				{
				sec[i][j/31]=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%31);
				}
			else
				{
				if(s<0)
					z+=1<<(j%31);
            }
			}
      sec[i][n/31]=z;
      ok=1;
      for (t=0;t<i;t++)
          {
			 if (!cmp(sec[i],sec[t]))
             {
             ok=0;
             break;
             }
          }     
      if (ok)
         k++;                        
      }
	fout<<k<<"\n";
	return 0;
	}