【AcWing】871. 约数之和

分解完质因数后,直接代入求和公式。

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<unordered_map>
using namespace std;

typedef long long LL;

const int mod=1e9+7;

int main(){
    int n;cin>>n;
    
    unordered_map<int,int> primes;//哈希表存储分解质因数的底数和指数
    
    while(n--){
        int x;
        cin>>x;
        for(int i=2;i<=x/i;i++){//每个数分解质因数
            while(x%i==0){
                x/=i;
                primes[i]++;//记录底数和指数
            }
        }
        if(x>1) primes[x]++;//大于sqrt(x)的质因数
    }
    
    LL res=1;
    for(auto prime:primes){
        int p=prime.first,a=prime.second;//p是底数,a是指数
        LL t=1;
        while(a--){//乘指数次
            t=(t*p+1)%mod;//求每一个p的和
        }
        res=res*t%mod;//相乘
    }
    cout<<res<<endl;
    return 0;
}
相关推荐
Data_agent8 小时前
学术爬虫实战:构建知网论文关键词共现网络的技术指南
python·算法
龚礼鹏8 小时前
Android应用程序 c/c++ 崩溃排查流程
c语言·开发语言·c++
立志成为大牛的小牛9 小时前
数据结构——五十五、散列查找的性能分析(线性探测法)(王道408)
数据结构·程序人生·考研·算法
神也佑我橙橙9 小时前
Thrift 简单介绍
算法
simon_skywalker9 小时前
线性代数及其应用习题答案(中文版)第二章 矩阵代数 2.1 矩阵运算(2)
线性代数·算法·矩阵
jiayong2310 小时前
数据结构时间复杂度完全解析
数据结构
REDcker10 小时前
JS 与 C++ 语言绑定技术详解
开发语言·javascript·c++
June`10 小时前
C++11新特性全面解析(三):智能指针与死锁
开发语言·c++
断剑zou天涯10 小时前
【算法笔记】Manacher算法
java·笔记·算法
monster000w11 小时前
大模型微调过程
人工智能·深度学习·算法·计算机视觉·信息与通信