Cod sursa(job #2391677)

Utilizator Constantin.Dragancea Constantin Constantin. Data 29 martie 2019 09:16:29
Problema Principiul includerii si excluderii Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.58 kb
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;

bool c[(1<<20)];
int n, pr[(1<<17)], p;
ll a, b;

int main(){
    ifstream cin ("pinex.in");
    ofstream cout ("pinex.out");
    cin >> n;
    for (int i=2; i<=1e6; i++){
        if (c[i]) continue;
        pr[++p] = i;
        for (int j=2*i; j<=1e6; j+=i) c[j] = 1;
    }
    for (int i=1; i<=n; i++){
        cin >> a >> b;
        for (int i=1; pr[i]<=sqrt(b); i++){
            if (b % pr[i]) continue;
            a -= a/pr[i];
        }
        cout << a << '\n';
    }
    return 0;
}