acwing870,求约数个数

如果
则约数个数为
#include <bits/stdc++.h>

using namespace std;

const int mod=1e9+7;
int n;
int a;
unordered_map<int,int> primes;

int main(int argc, char** argv) {
	cin>>n;
	while(n--){
		cin>>a;
		for(int i=2;i<=a/i;i++){
			while(a%i==0){
				primes[i]++;
				a/=i;
			}
		}
		if(a>1) primes[a]++;
	}
	long long  ans=1;
	for(auto it:primes){
		ans=ans*(it.second+1)%mod;
	}
	cout<<ans<<endl;
	return 0;
}

全部评论

相关推荐

2025-11-14 11:26
南京理工大学 Java
东北桌角王:有的,感觉可能实习生发癫多一些,我之前加了字节的 hr,在微信上从晚上八点聊天到12 点,狠狠的诉苦啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务