Cod sursa(job #2887740)

Utilizator DafinaTrufasTrufas Dafina DafinaTrufas Data 10 aprilie 2022 09:24:19
Problema Loto Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.19 kb

#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;
}