Cod sursa(job #271591)

Utilizator jeanFMI - Petcu Ion Cristian jean Data 5 martie 2009 16:28:10
Problema Loto Scor 85
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.19 kb
#include<fstream>
using namespace std;
int v[100],sum[1000010],i,s,d,m,k,poz,S,j,l,x,poz1,poz2,n,ok;
struct sir {int x,y,z;} a[1000010],aux;

int pozitie(int i, int j)
{
int di=1,dj=0,aux2;
while(i<j)
 { if(sum[i]>sum[j]) { aux2=sum[i]; sum[i]=sum[j]; sum[j]=aux2;
                       aux=a[i]; a[i]=a[j]; a[j]=aux;
                       aux2=di; di=dj; dj=aux2;
                     }
   i+=di;
   j-=dj;
 }
return i;
}
void quick(int s, int d)
 { if(s<d)
    {int p=pozitie(s,d);
      quick(s,p-1);
      quick(p+1,d);
    }
 }
int main()
{
ifstream f("loto.in");
ofstream g("loto.out");
f>>n>>S;
for(i=1;i<=n;i++) f>>v[i];

for(i=1;i<=n;i++)
 for(j=i;j<=n;j++)
  for(l=j;l<=n;l++)
    { sum[++k]=v[i]+v[j]+v[l];
      a[k].x=v[i]; a[k].y=v[j]; a[k].z=v[l];
    }
quick(1,k);

for(i=1;i<=k;i++)
 { x=S-sum[i]; s=1;d=k;

    while(s<=d)

      {m=(s+d)>>1;
        if(sum[m]>x) d=m-1;
        else if(sum[m]<x) s=m+1;
        else break;
      }
   if(s<=d) {ok=1; poz1=i; poz2=m; break;}
  }
if(!ok) g<<"-1";
else g<<a[poz1].x<<" "<<a[poz1].y<<" "<<a[poz1].z<<" "<<a[poz2].x<<" "<<a[poz2].y<<" "<<a[poz2].z;
f.close();
g.close();
return 0;
}