AcWing 197. 阶乘分解
. 阶乘分解
一、题目描述
给定整数 ,试把阶乘 分解质因数,按照算术基本定理的形式输出分解结果中的 和 即可。
输入格式
一个整数 。
输出格式
分解质因数后的结果,共若干行,每行一对 ,表示含有 项。按照 从小到大的顺序输出。
数据范围
输入样例:
5
输出样例:
2 3
3 1
5 1
样例解释
5!=120=2^3∗3∗5
二、方法
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
int n;
bool prime(int x) {
if (x == 2) return 1;
for (int i = 2; i * i <= x; i++)
if (x % i == 0) return 0;
return 1;
}
int main() {
cin >> n;
for (int i = 2; i <= n; i++) {
if (!prime(i)) continue;
LL x = i;
int ans = 0;
while (x <= n) ans += n / x, x *= i;
printf("%d %d\n", i, ans);
}
return 0;
}
三、方法
- 筛出的所有质数
- 枚举每个质因子,表示,从到中,求的次数:
(直到的次方大于停止)
举栗子:
比如里有多少个的倍数,
有多少个的倍数
有多少个的倍数
共个,与例子对的上。
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
// 欧拉筛
const int N = 1e6 + 10;
int primes[N], cnt; // primes[]存储所有素数
bool st[N]; // st[x]存储x是否被筛掉
void get_primes(int n) {
memset(st, 0, sizeof st);
cnt = 0;
for (int i = 2; i <= n; i++) {
if (!st[i]) primes[cnt++] = i;
for (int j = 0; primes[j] * i <= n; j++) {
st[primes[j] * i] = true;
if (i % primes[j] == 0) break;
}
}
}
int main() {
int n;
cin >> n;
get_primes(n);
for (int i = 0; i < cnt; i++) {
int p = primes[i];
int s = 0;
// 思路:由大到小+除法降维
// 优点:不用考虑乘法而导致的爆int上限
for (int j = n; j; j /= p) s += j / p;
printf("%d %d\n", p, s);
}
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!