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;
}
相关推荐
6Hzlia7 小时前
【Hot 100 刷题计划】 LeetCode 739. 每日温度 | C++ 逆序单调栈
c++·算法·leetcode
良木生香7 小时前
【C++初阶】:STL——String从入门到应用完全指南(1)
c语言·开发语言·数据结构·c++·算法
XWalnut7 小时前
LeetCode刷题 day16
数据结构·算法·leetcode·链表·动态规划
foundbug9999 小时前
基于混合整数规划的电池容量优化 - MATLAB实现
数据结构·算法·matlab
memcpy010 小时前
LeetCode 2452. 距离字典两次编辑以内的单词【暴力;字典树】中等
算法·leetcode·职场和发展
王老师青少年编程11 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【排序贪心】:魔法
c++·算法·贪心·csp·信奥赛·排序贪心·魔法
wearegogog12311 小时前
基于和差波束法的单脉冲测角MATLAB实现
人工智能·算法·matlab
AI科技星11 小时前
灵魂商数(SQ) · 全域数学统一定义【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
晓觉儿11 小时前
【GPLT】2026年第十一届团队程序设计天梯赛赛后题解(已写2h,存档中)
数据结构·c++·算法·深度优先·图论