Cod sursa(job #2068045)

Utilizator Mihai145Oprea Mihai Adrian Mihai145 Data 17 noiembrie 2017 09:34:02
Problema Divizori Primi Scor 55
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.88 kb
#include <bits/stdc++.h>
using namespace std;
ifstream fin("divprim.in");
ofstream fout("divprim.out");
int t, n, k;
int nrd[1000002];
void ciur()
{
    int i, j;
    for(i=3; i<=1000000; i+=2)
        if(!nrd[i])
            for(j=i; j<=1000000; j+=i)
                nrd[j]++;
}
int main()
{
    int i, j, x;
    bool ok;
    ciur();
    fin>>t;
    for(i=1; i<=t; i++)
    {
        ok=0;
        fin>>n>>k;
        if(k==0)
            {
                fout<<1<<'\n';
                ok=1;
            }
        else
        {
            for(j=n; j>=2; j--)
            {
                x=nrd[j]+(1-j%2);
                if(x==k)
                {
                    fout<<j<<'\n';
                    ok=1;
                    break;
                }
            }
        }
        if(!ok)
            fout<<0<<'\n';
    }
    return 0;
}