题
约束的个数都加一,然后全部乘在一起。
代码:
学到了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; }