Pagini recente » Cod sursa (job #1178289) | Cod sursa (job #376533) | Cod sursa (job #1147837) | Cod sursa (job #1688005) | Cod sursa (job #42331)
Cod sursa(job #42331)
#include <stdio.h>
struct dr { short a,b,c; };
dr drepte[1005];
char grupe[1005][130],aux[130];
int k,x,y,gas;
int n,m,i,j,nr;
FILE *fin,*fout;
int strcmp(char a[],char b[])
{
int i=0;
for (i=0;i<=129;i++)
if (a[i]!=b[i])
return 1;
return 0;
}
void setbit(char a[],int bt)
{ int r=bt%8;
int i=bt/8;
a[i]|=1<<r;
}
int main()
{
fin=fopen("regiuni.in","rt");
fout=fopen("regiuni.out","wt");
fscanf(fin,"%d %d\n",&n,&m);
for (i=0;i<n;i++)
fscanf(fin,"%d %d %d\n",&drepte[i].a,&drepte[i].b,&drepte[i].c);
for (i=0;i<m;i++)
{ fscanf(fin,"%d %d\n",&x,&y);
j=0;
for (j=0;j<129;j++)
aux[j]=0;
nr=0;
for (j=0;j<n;j++)
if (drepte[j].a*x+drepte[j].b*y+drepte[j].c>0)
setbit(aux,nr++);
gas=0;
for (j=0;j<k;j++)
if (strcmp(aux,grupe[j])==0)
{gas=1;
break;
}
if (gas==0)
{
j=0;
for (j=0;j<129;j++)
grupe[k][j]=aux[j];
grupe[k][j]=0;
k++;
}
}
fprintf(fout,"%d\n",k);
return 0;
}