标签:des style http java color os strong io
2 2 2 10 10
Case 1: 1 Case 2: 2
#include <iostream> #include <cstdio> #include <cstring> #include <vector> #include <string> #include <algorithm> #include <queue> using namespace std; #define LL unsigned long long const int maxn = 10000005; bool isPrime[maxn]; vector<LL> prime,digit,cnt; void getPrime(){ prime.clear(); memset(isPrime,0,sizeof isPrime); for(LL i = 2; i < maxn; i++){ if(!isPrime[i]){ prime.push_back(i); for(LL j = i*i; j < maxn; j += i) isPrime[j] = 1; } } } void getDigit(LL k){ for(int i = 0; i < prime.size() && k >= prime[i]; i++){ if(k%prime[i]==0){ int tt = 0; digit.push_back(prime[i]); while(k%prime[i]==0){ tt++; k /= prime[i]; } cnt.push_back(tt); } } if(k!=1){ digit.push_back(k); cnt.push_back(1); } } LL getSum(LL n,LL p){ LL res = 0; while(n){ n /= p; res += n; } return res; } int main(){ int ncase,T=1; LL k,n; getPrime(); cin >> ncase; while(ncase--){ cin >> n >> k; if(k==1){ printf("Case %d: inf\n",T++); continue; } LL ans = -1; digit.clear(); cnt.clear(); getDigit(k); for(int i = 0; i < digit.size(); i++){ LL tk = getSum(n,digit[i])/cnt[i]; if(ans == -1) ans = tk; else ans = min(ans,tk); } printf("Case %d: %I64u\n",T++,ans); } return 0; }
HDU3988-Harry Potter and the Hide Story(数论-质因数分解),布布扣,bubuko.com
HDU3988-Harry Potter and the Hide Story(数论-质因数分解)
标签:des style http java color os strong io
原文地址:http://blog.csdn.net/mowayao/article/details/38281545