给定整数 N ,试把阶乘 N! 分解质因数,按照算术基本定理的形式输出分解结果中的 和 即可。
输入格式
一个整数N。
输出格式
N! 分解质因数后的结果,共若干行,每行一对,表示含有项。按照从小到大的顺序输出。
数据范围
输入样例:
5
输出样例:
2 3
3 1
5 1
样例解释
水题,分解质因数,然后看到一个不一样的做法,是真的惊艳到我了,或许以后能够借鉴他的思路,换个角度思考问题。
思路,先用筛子筛出内的素数,然后考虑这个数,对于每个素数而言,是的倍,也就是说,对于小于等于的数,形如这种形式有个,那么很容易的得到,对于而言,有个数是的倍数,即能被整除;然后我们将与上面的含义一样,意为计算有几个的倍数,这一步操作我们将,含义一样。
#include <bits/stdc++.h>
using namespace std;
const int N = 1e6+10;
int n,prime[N],tot;
bool st[N];
void init(){
for(int i=2;i<=N;++i){
if(!st[i]){
prime[++tot] = i;
if(i>=10000)continue;
for(int j=i*i;j<=N;j+=i)st[j] = true;
}
}
}
int main(){
init();
scanf("%d",&n);
for(int i=1;prime[i]<=n;++i){
int now = n,ans = 0;
while(now){
ans+=(now/prime[i]);
now/=prime[i];
}
printf("%d %d\n",prime[i],ans);
}
return 0;
}