Pagini recente » Cod sursa (job #2656432) | Cod sursa (job #1161174) | Cod sursa (job #922065) | Cod sursa (job #2907774) | Cod sursa (job #2887634)
#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;
int n, ok = 0, i, j, k, m, aux;
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[(s - v[i] - v[j] - v[k]) % p].pr)
{
g << v[i] << ' ' << v[j] << ' ' << v[k] << ' ' << sume_trei[s - v[i] - v[j] - v[k]].pr << ' ' << sume_trei[s - v[i] - v[j] - v[k]].sc << ' ' << sume_trei[s - v[i] - v[j] - v[k]].tr;
return 0;
}
}
g << -1;
return 0;
}