2018-2019 ACM-ICPC, Asia Dhaka Regional ContestC[数论]

题意很简单 求n! 的因子的因子的个数

首先对于任意一个数字 他的因子的个数等于将这个数字分解质因数后 每个质因数的次数加1 的乘积

我们将n!进行质因数分解之后 对于某个质因数p 假设他的最高次数为a 那么我们可以选择0次 1次2次3...... a次 对于每次选择 他的因子的个数就可以为次数加一 那么总的贡献就是 1+2+3+4+......+a+1= (a+1)*(a+2)/2;

那么所有的质因数的总贡献乘积就是答案 也就是

代码实现如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define int long long
const int mod=1e7+7;
const int N=1e6+5;
int qpow(int a,int b){
    int ans=1;
    for(;b;b>>=1){
        if(b&1)ans=ans*a%mod;
        a=a*a%mod;
    }
    return ans;
}
vector<int>minp(N,0),primes;
void sieve(int n){
    minp.assign(n+1,0);
    primes.clear();
    for(int i=2;i<=n;i++){
        if(!minp[i]){
            minp[i]=i;
            primes.push_back(i);
        }
        for(auto p:primes){
            if(i*p>n)break;
            minp[i*p]=p;
            if(p==minp[i])break;
        }
    }
}
signed main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    sieve(N-4);
    int n;
    while(cin>>n&&n!=0){
        int ans=1;
        for(auto p:primes){
            if(p>n)break;
            int cnt=0;
            for(int j=n;j;j/=p)cnt+=j/p;
            ans=(ans*(cnt+1)%mod*(cnt+2)%mod)%mod *5000004%mod;
        }
        cout<<ans<<'\n';
    }
    return 0;
}
相关推荐
洛水水几秒前
【力扣100题】48.乘积最大子数组
算法·leetcode·职场和发展
小小de风呀1 分钟前
de风——【从零开始学C++】(七):string类详解
开发语言·c++·算法
YL200404261 分钟前
042将有序数组转换为二叉搜索树
数据结构·算法·leetcode
qq_296553275 分钟前
矩阵对角线遍历:从暴力到最优的优雅解法
数据结构·线性代数·算法·青少年编程·矩阵·深度优先遍历
洛水水6 分钟前
【力扣100题】50.最长有效括号
算法·leetcode·职场和发展
数智工坊7 分钟前
【BLIP论文阅读】:统一视觉语言理解与生成的自举式预训练范式
论文阅读·人工智能·深度学习·算法·transformer
yyy(十一月限定版)8 分钟前
问题解决策略搜索训练3
算法
吃好睡好便好10 分钟前
在Matlab中绘制圆锥三维曲面图
开发语言·人工智能·学习·算法·matlab·信息可视化
兰令水11 分钟前
topcode【随机算法题】【2026.5.15打卡-java版本】
java·算法·leetcode
洛水水12 分钟前
【力扣100题】44.完全平方数
算法·leetcode·职场和发展