Pagini recente » Cod sursa (job #2279535) | Cod sursa (job #1993826) | Cod sursa (job #3152155) | Cod sursa (job #1918845) | Cod sursa (job #987351)
Cod sursa(job #987351)
# include <iostream>
# include <fstream>
# include <vector>
# include <algorithm>
using namespace std;
# define MAXN 103
# define MOD 666013
ifstream f("loto.in");
ofstream g("loto.out");
int n, s;
int a[MAXN];
vector<int> hassh[MOD];
void addHash(int x) {
int aux = x % MOD;
hassh[aux].push_back(x);
}
bool getHash(int x) {
bool ok = false;
int aux = x % MOD;
for (int i = 0; i < hassh[aux].size(); i++) {
if (hassh[aux][i] == x) {
ok = true;
break;
}
}
return ok;
}
int main()
{
f >> n >> s;
for (int i = 1; i <= n; i++) {
f >> a[i];
addHash(a[i]);
}
sort(a + 1, a + n + 1);
for (int i = n; i >= 1; i--) {
for (int j = n; j >= 1; j--) {
for (int k = n; k >= 1; k--) {
for (int l = n; l >= 1; l--) {
for (int m = n; m >= 1; m--) {
int aux = s - a[i] - a[j] - a[k] - a[l] - a[m];
if (aux > 0) {
if (getHash(aux) == true) {
g << a[i] << ' ' << a[j] << ' ' << a[k] << ' ';
g << a[l] << ' ' << a[m] << ' ' << aux;
return 0;
}
}
}
}
}
}
}
g << -1;
return 0;
}