Pagini recente » Cod sursa (job #3179134) | Cod sursa (job #208199) | Cod sursa (job #2198797) | Cod sursa (job #2693637) | Cod sursa (job #1588776)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fi("gfact.in");
ofstream fo("gfact.out");
long long p, q;
long long zero(long long n){
long long r = 0;
while (n >= p){
r += n / p;
n /= p;
}
return r;
}
long long cautbin()
{
long long i = 0;
int pas = (long long)1 << 30;
while (pas != 0)
{
if (zero(i + pas) < q)
i += pas;
pas /= 2;
}
return i+1;
}
int main()
{
long long nr;
fi >> p >> q;
nr = cautbin();
if (zero(nr) == q)
fo << nr;
else fo << -1;
}