Pagini recente » Cod sursa (job #1830901) | Cod sursa (job #2097870) | Cod sursa (job #68676) | Cod sursa (job #3229894) | Cod sursa (job #1478789)
#include <iostream>
#include <fstream>
#include <bitset>
#include <cmath>
using namespace std;
ifstream fin("zero2.in");
ofstream fout("zero2.out");
const int NMax = 1e5;
int k;
int primes[NMax];
bitset < NMax > ciur;
inline void eratos(){
primes[++k] = 2;
for(int i = 3; i < NMax; i += 2){
if(!ciur[i]){
primes[++k] = i;
for(int j = 2 * i; j < NMax; j += i){
ciur[j] = 1;
}
}
}
}
int main(){
int t = 10;
eratos();
int n, b, cnt, ans;
while(t--){
fin >> n >> b;
ans = NMax;
for(int i = 1; primes[i] <= b; i++){
if(b % primes[i] == 0){
cnt = 0;
while(b % primes[i] == 0){
b /= primes[i];
cnt++;
}
if(cnt != 0){
ans = min(ans, max(0, (n - primes[i] + 1) / cnt));
}
}
}
fout << ans << "\n";
}
return 0;
}