Cod sursa(job #3259518)

Utilizator vladm98Munteanu Vlad vladm98 Data 26 noiembrie 2024 18:14:17
Problema Suma si numarul divizorilor Scor 30
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.91 kb
#include <fstream>
using namespace std;

ifstream f("ssnd.in");
ofstream g("ssnd.out");

int ridicare(int a, int n) {
    int rasp = 1;
    while(n > 0) {
        if(n % 2 == 1)
            rasp = rasp * a;
        a = a * a;
        n /= 2;
    }
    return rasp;
}

const int MOD = 9973;

int main() {
    int t, x, nr_div, sum_div, d, p, num;
    f>>t;
    for(int i = 1; i<=t; i++){
        f>>x;
        nr_div = 1;
        sum_div = 1;
        d = 2;
        while(x>1){
            if(x%d==0){
                p = 0;
                num = 1;
                while(x%d==0){
                    p++;
                    x /= d;
                }
                nr_div *= (p+1);
                sum_div = (sum_div*(ridicare(d, p+1)-1)/(d-1));
            }
            d++;
            if(x>1 && d*d>x){
                d=x;
            }
        }
        g<<nr_div % MOD <<" "<<sum_div % MOD <<"\n";
    }
    return 0;
}