Pagini recente » Cod sursa (job #674135) | Cod sursa (job #239688) | Cod sursa (job #2416280) | Cod sursa (job #899806) | Cod sursa (job #1089024)
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
ifstream fin("loto.in");
ofstream fout("loto.out");
#define MAX 102
int a[MAX];
int b[MAX*MAX*MAX];
int c[6];
int n,s;
int t;
int cautare(int s1)
{
int st=1,dr=t,m;
int x=s-s1;
while(st<=dr)
{
m=(st+dr)/2;
if(b[m]==x)
return m;
if(b[m]>x)
st=m+1;
else
dr=m-1;
}
return 0;
}
int main()
{
int i,j,k;
fin>>n>>s;
for(i=1;i<=n;i++)
fin>>a[i];
t=0;
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
for(k=1;k<=n;k++){
b[++t]=a[i]+a[j]+a[k];
}
sort(b+1,b+t+1);
bool ok=0;
int x1,x2;
for(i=1;i<=t;i++){
j=cautare(b[i]);
if(j){
x1=i;
x2=j;
ok=1;
break;
}
}
if(!ok)
{
fout<<-1<<"\n";
return 0;
}
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
for(k=1;k<=n;k++){
if(b[x1]==a[i]+a[j]+a[k]){
c[0]=a[i];
c[1]=a[j];
c[2]=a[k];
goto next;
}
}
next:
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
for(k=1;k<=n;k++){
if(b[x2]==a[i]+a[j]+a[k]){
c[3]=a[i];
c[4]=a[j];
c[5]=a[k];
goto sebi;
}
}
sebi:
sort(c,c+6);
for(i=0;i<6;i++)
fout<<c[i]<<" ";
return 0;
}