Pagini recente » Cod sursa (job #3345395) | Cod sursa (job #2646694) | Cod sursa (job #1064877) | Cod sursa (job #3286311) | Cod sursa (job #3331083)
#include <bits/stdc++.h>
using namespace std;
int nrprim[15];
int totprim[15];
int k=0;
void Desc(int a)
{
int d=2;
while(a>1)
{
int cnt=0;
while(a%d==0)
{
cnt++;
a=a/d;
}
if(cnt!=0)
{
nrprim[k]=d;
totprim[k]=cnt;
k++;
}
if(d*d>a && a!=1)
{
d=a;
}
d++;
}
}
int main()
{
ifstream cin("gfact.in");
ofstream cout("gfact.out");
int p,q;
int rez=0;
cin>>p>>q;
Desc(p);
for(int i=0;i<k;i++)
{
int cnt=totprim[i]*q;
int nr=nrprim[i];
int j=nr;
while(cnt>0)
{
int cj=j;
while(cj%nr==0)
{
cnt--;
cj=cj/nr;
}
if(cnt<=0)
break;
j+=nr;
}
rez=max(rez,j);
}
cout<<rez;
return 0;
}