Cod sursa(job #2936164)

Utilizator rapidu36Victor Manz rapidu36 Data 8 noiembrie 2022 11:02:26
Problema Sum Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.78 kb
#include <fstream>

using namespace std;

const int VMAX = 1e5;

int e[VMAX+1];

int main()
{
    ifstream in("sum.in");
    ofstream out("sum.out");
    ///precalculez vectorul e cu e[i]=indicatorul lui Euler pentru i
    for (int i = 2; i <= VMAX; i++)
    {
        e[i] = i;
    }
    for (int i = 2; i <= VMAX; i++)
    {
        if (e[i] == i)///i este prim
        {
            for (int multiplu = i; multiplu <= VMAX; multiplu += i)///parcurg multiplii lui i
            {
                e[multiplu] = e[multiplu] / i * (i - 1);
            }
        }
    }
    int n;
    in >> n;
    for (int i = 0; i < n; i++)
    {
        int x;
        in >> x;
        out << 2LL * x * e[x] << "\n";
    }
    in.close();
    out.close();
    return 0;
}