Acwing.197. 阶乘分解(题解)

2020-12-23 17:28

阅读:771

标签:flow   org   hid   结果   pre   font   问题   基本   atom   

给定整数 N ,试把阶乘 N! 分解质因数,按照算术基本定理的形式输出分解结果中的 pici 即可。

输入格式

一个整数N。

输出格式

N! 分解质因数后的结果,共若干行,每行一对pi,ci,表示含有pici项。按照pi从小到大的顺序输出。

数据范围

1N106

输入样例:

5

输出样例:

2 3
3 1
5 1

样例解释

5!=120=23?3?5

水题,分解质因数,然后看到一个不一样的做法,是真的惊艳到我了,或许以后能够借鉴他的思路,换个角度思考问题。
思路,先用筛子筛出\(10^6\)内的素数,然后考虑\(n\)这个数,对于每个素数\(x\)而言,\(n\)\(x\)\(n/x\)倍,也就是说,对于小于等于\(x\)的数,形如\(x,2x,3x...kx\)这种形式有\(\lfloor \frac{n}{x} \rfloor\)个,那么很容易的得到,对于\(x\)而言,有\(\lfloor \frac{n}{x} \rfloor\)个数是\(x\)的倍数,即能被\(x\)整除;然后我们将\(x*x\)与上面的含义一样,意为计算\(n\)有几个\(x*x\)的倍数,这一步操作我们将\(n/x\),含义一样。
\(Code:\)

#include 
using namespace std;
const int N = 1e6+10;
int n,prime[N],tot;
bool st[N];
void init(){
    for(int i=2;i=10000)continue;
            for(int j=i*i;j

Acwing.197. 阶乘分解(题解)

标签:flow   org   hid   结果   pre   font   问题   基本   atom   

原文地址:https://www.cnblogs.com/violentbear/p/14157022.html


评论


亲,登录后才可以留言!