Cod sursa(job #811161)

Utilizator HotSteelBeteag Ion Andrei HotSteel Data 11 noiembrie 2012 16:38:28
Problema Divizori Primi Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.77 kb
#include <cstdio>
#include <vector>

using namespace std;

//vector<int> div;
//vector< vector<int> > mat;

int div[1000005];
int mat[1000000][7];

void ciur()
{
    long i,j;

    for(i=2;i<=1000000;i+=2)
        div[i]++;
    for(i=3;i<=1000000;++i)
        if(!div[i])
            for(j=i;j<=1000000;j+=i)
                div[j]++;

    for(i=2;i<=1000000;++i)
    {
        for(j=0;j<=7;++j)
            mat[i][j]=mat[i-1][j];
        mat[i][div[i]]=i;
    }
}

int main()
{
    freopen("divprimi.in","r",stdin);
    freopen("divprimi.out","w",stdout);

    ciur();

    long t,n,k;
    scanf("%ld",&t);

    long i;
    for(i=1;i<=t;++i)
    {
        scanf("%ld%ld",&n,&k);
        printf("%ld\n",mat[n][k]);
    }

    return 0;
}