Cod sursa(job #647483)

Utilizator BlaugranasEnal Gemaledin Blaugranas Data 11 decembrie 2011 15:23:16
Problema Cutii Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.87 kb
#include<cstdio>
#include<algorithm>
using namespace std;
#define N 3501
struct P
{int x,y,z;};
P p[N];
int i,n,t,m,k,b[N],j,c;

int C(P a,P b)
{return a.x<b.x;}

int main()
{FILE *f=fopen("cutii.in","r"),*g=fopen("cutii.out","w");
fscanf(f,"%d%d",&n,&t);
while(t--)
      {for(i=1;i<=n;i++)
              fscanf(f,"%d%d%d",&p[i].x,&p[i].y,&p[i].z);
      sort(p+1,p+n+1,C);
      for(i=1,m=0;i<=n;i++)
              {if(p[b[m]].y<p[i].y&&p[b[m]].z<p[i].z)
                      b[++m]=i;
              for(j=0,k=m;j<k;)
                      {c=(j+k)/2;
                      if(p[b[c]].y<p[i].y&&p[b[c]].z<p[i].z)
                              j=c+1;
                      else
                              k=c;}
              if(p[i].y<p[b[j]].y||(p[i].y==p[b[j]].y&&p[i].z<p[b[j]].z))
                      b[j]=i;}
      fprintf(g,"%d\n",m);}
return 0;}