Cod sursa(job #497411)

Utilizator ivan_marianIvan Liviu Marian ivan_marian Data 2 noiembrie 2010 14:13:39
Problema Loto Scor 55
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.81 kb
#include<stdio.h>
#include<algorithm>
using namespace std;
FILE *f=fopen("loto.in","r");
FILE *g=fopen("loto.out","w");
struct loto{
	int s,x,y,z;
}b[1000001];
int n,s,i,p,u,m,j,a[101],k,ma;
int cmp(loto a,loto b){
	if (a.s<=b.s)
		return 1;
	return 0;
}
int main(){
	fscanf(f,"%d %d",&n,&s);
	for (i=1;i<=n;i++)
		fscanf(f,"%d",&a[i]);
	
	
	
	for(i=1;i<=n;i++)
		for(j=i;j<=n;j++)
			for(k=j;k<=n;k++){
				ma++;
				b[ma].s=a[i]+a[j]+a[k];
				b[ma].x=i;
				b[ma].y=j;
				b[ma].z=k;
			}
	sort (b+1,b+ma+1,cmp);
	
	for(i=1;i<=ma;i++){
		p=1;
		u=ma;
		while(p<=u){
			m=(p+u)/2;
			if (s-b[i].s==b[m].s){
				fprintf(g,"%d %d %d %d %d %d",a[b[i].x],a[b[i].y],a[b[i].z],a[b[m].x],a[b[m].y],a[b[m].z]);
				return 0;
			}
			else
				if (s-b[i].s<b[m].s)
					u=m-1;
				else
					p=m+1;
		}
	}
	fprintf(g,"-1");
	return 0;
}