【每日算法】基础算法——约数之和(五十九)

题目内容

给定n个正整数ai,请你输出这些数的乘积的约数之和,答案对10^9+7取模。

输入格式

第一行包含整数n。

接下来n行,每行包含一个整数ai。

输出格式

输出一个整数,表示所给正整数的乘积的约数之和,答案需对10^9+7取模。

数据范围

1≤n≤100 ,
1≤ai≤2*10^9

输入样例

3
2
6
8

输出样例

252

题解

代码

#include <iostream>
#include <algorithm>
#include <unordered_map> //由于约数最大有2*10^9级别,数组开不了这么大,因此用hash表来做

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]++;
}

LL res = 1;
for(auto prime : primes) {
int p = prime.first; //表示质数的底数
int a = prime.second; //表示质数的指数
LL t = 1;
while(a--) t =( t * p + 1) % mod;
res = res * t % mod;
}

cout<< res << endl;

return 0;
}
Author: Frederic Niu
Link: https://www.fredericniu.cn/2021/01/29/【每日算法】基础算法——约数之和(五十九)/
Copyright Notice: All articles in this blog are licensed under CC BY-NC-SA 4.0 unless stating additionally.
我的公众号