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;
}
相关推荐
Frostnova丶2 小时前
LeetCode 3474. 字典序最小的生成字符串
算法·leetcode·职场和发展
REDcker2 小时前
Nagle 算法与 TCP_NODELAY、TCP_CORK 详解
网络·tcp/ip·算法
β添砖java2 小时前
深度优先搜索DFS
算法·深度优先
小糯米6012 小时前
C++ 并查集
java·c++·算法
IronMurphy2 小时前
【算法三十四】39. 组合总和
算法·深度优先
重庆小透明2 小时前
力扣刷题【3】相交链表
算法·leetcode·链表
算法鑫探2 小时前
C语言实战:学生成绩统计与分析
c语言·数据结构·算法·新人首发
IAUTOMOBILE2 小时前
Code Marathon 项目源码解析与技术实践
java·前端·算法
Lyyaoo.2 小时前
【JAVA基础面经】深拷贝与浅拷贝
java·开发语言·算法