Cod sursa(job #1328602)

Utilizator amina2002Abu Shanab Amina amina2002 Data 28 ianuarie 2015 16:30:43
Problema Divizori Primi Scor 35
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.04 kb
#include<cstdio>
#include<cmath>
using namespace std;
int c[80000],p[80000];
int u;
void ciur(int n)
{
    int lim,d=2,i,j;
    u=0;
    c[0]=c[1]=1;
    for(i=4; i<=n; i+=2)
        c[i]=1;
    lim=(int)sqrt((double)n);
    for(i=3; i<=lim; i+=2)
        if(c[i]==0)
            for(j=i*i; j<=n; j=j+(i<<1))
                c[j]=1;
    p[1]=2;
    u=1;
    for(i=3; i<=n; i+=2)
        if(c[i]==0)
            p[++u]=i;
}
int v[1000005];
void ciur2(int n)
{
  int i,j;
  for(i=1;i<=u;++i)
  {
    for(j=p[i];j<=n;j=j+p[i])
      v[j]++;
  }
}

int main()
{
    freopen("divprim.in","r",stdin);
    freopen("divprim.out","w",stdout);
    int i,ok,j;
    ciur(79999);
    ciur2(1000005);
    int t,n,k;
    scanf("%d",&t);
    for(i=1; i<=t; ++i)
    {
        scanf("%d%d",&n,&k);
        ok=0;
        for(j=n; j>=1; --j)
            if(v[j]==k)
            {
                ok=1;
                printf("%d\n",j);
                break;
            }
        if(ok==0)
            printf("0\n");
    }
}