Pagini recente » Cod sursa (job #225200) | Cod sursa (job #633187) | Cod sursa (job #2046677) | Cod sursa (job #1017674) | Cod sursa (job #1328602)
#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");
}
}