Pagini recente » Cod sursa (job #496887) | Cod sursa (job #1247294) | Cod sursa (job #2719947) | Cod sursa (job #1332497) | Cod sursa (job #2887740)
#include <iostream>
#include <fstream>
#include <unordered_map>
#include <vector>
using namespace std;
const int p = 666013;
struct triplet{
int pr, sc, tr;
} sume_trei[p + 2];
int main()
{
int v[100];
triplet t;
long long s, aux;
int n, ok = 0, i, j, k, m;
ifstream f("loto.in");
ofstream g("loto.out");
f >> n >> s;
for(i = 0; i < n; i++)
f >> v[i];
for(int i = 0; i < n; i++)
for(int j = i; j < n; j++)
for(int k = j; k < n; k++)
{
t.pr = v[i]; t.sc = v[j]; t.tr = v[k];
sume_trei[(v[i] + v[j] + v[k]) % p] = t;
}
for(int i = 0; i < n; i++)
for(int j = i; j < n; j++)
for(int k = j; k < n; k++)
{
aux = (s - v[i] - v[j] - v[k]) % p;
if(aux < 0) aux += p;
if(sume_trei[aux].pr)
{
if(v[i] + v[j] + v[k] + sume_trei[aux].pr + sume_trei[aux].sc + sume_trei[aux].tr == s)
{
g << v[i] << ' ' << v[j] << ' ' << v[k] << ' ' << sume_trei[aux].pr << ' ' << sume_trei[aux].sc << ' ' << sume_trei[aux].tr;
return 0;
}
}
}
g << -1;
return 0;
}