算法AcWing 870. 约数个数

Posted karshey

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法AcWing 870. 约数个数相关的知识,希望对你有一定的参考价值。

算法思想

约束的个数都加一,然后全部乘在一起。
在这里插入图片描述

代码:
学到了unordered_map
因为x在循环过程中会变小,所以可能x还没被完全分解就退出循环了,所以要有if(x>1)那个判断。

#include<iostream>
#include<unordered_map>
#define LL long long int 
using namespace std;

const int MOD=1e9+7;

int main()
{
	int n;cin>>n;
	unordered_map<int,int>a;
	
	while(n--)
	{
		int x;cin>>x;
		
		for(int i=2;i<=x/i;i++)
		{
			while(x%i==0)
			{
				a[i]++;
				x/=i;
			}
		}
		
		//最后一个最大公约数 
		if(x>1) a[x]++;
		
	
	}
	LL ans=1;
	for(auto i:a) ans=ans*(i.second+1)%MOD;
		
	cout<<ans;
	return 0;
}

以上是关于算法AcWing 870. 约数个数的主要内容,如果未能解决你的问题,请参考以下文章

(寒假练习 AcWing 870)约数个数(数论)

870. 约数个数

AcWing 198. 反素数 约数个数+dfs

AcWing 1294. 樱花 数学推导+约数个数

《算法竞赛进阶指南》0x32约数

算法AcWing 871. 约数之和