HDU-4190-Number Sequence-容斥原理+多重集和的r组合
HDU-4190-Number Sequence-容斥原理+多重集和的r组合
【Problem Description】
给你\(n\)个数\(b_i\),问有多少个长度为\(n\)序列\(a_i\),使得\(a_1\cdot a_2\dots a_n=b_1\cdot b_2\dots b_n\)。且\(a_i>1\)。
【Solution】
将所有\(b_i\)分解质因数,并分别统计每个质因数出现的次数,那么可以肯定,所有的\(a_i\)一定是从这些质因数中选取不同的组合相乘得到的。
假设没有\(a_i>1\)的限制,然后假设所有的\(b_i\)共有\(3\)个质因子,每个质因子出现的次数分别为\(a,b,c\)次。则总共有\({a+n-1\choose n-1}\cdot {b+n-1\choose n-1}\cdot {c+n-1\choose n-1}\)种长度为\(n\)的\(a_i\)序列。即类似总共有\(n\)个不同的盒子,将\(a\)个红球,\(b\)个蓝球,\(c\)个绿球放进这\(n\)个盒子中有多少种不同的方案,可以使得。
但是现在求得的答案数包括了\(a_i=1\)的情况,需要去除,即减去\(1\)个位置为空的方案数,再加上\(2\)个位置为空的方案数,再减去\(\dots\)等等。\(i\)个位置为空的方案数为\({n\choose i}\cdot {a+n-1-i\choose n-1-i}\cdot {b+n-1-i\choose n-1-i}\cdot {c+n-1-i\choose n-1-i}\)。即先从\(n\)个盒子种选\(i\)个位置,有\({n\choose i}\)种方案,然后再乘以将\(a\)个红球,\(b\)个蓝球,\(c\)个绿球放进\(n-i\)个盒子中的方案数。
【Code】
#include<iostream>
#include<algorithm>
#include<map>
#include<cstring>
#include<cstdio>
using namespace std;
#define INF 0x3f3f3f3f
#define maxn 1000005
#define int long long
const int mod=1e9+7;
int a[25];
int prime[maxn],cnt=0;
bool vis[maxn]={1,1};
void Euler(){ //欧拉筛
for(int i=2;i<maxn;i++){
if(!vis[i]) prime[++cnt]=i;
for(int j=1;j<=cnt&&i*prime[j]<maxn;j++){
vis[i*prime[j]]=1;
if(i%prime[j]==0) break;
}
}
}
map<int,int>mp; //统计每个质因数出现的次数
void solve(int n){ //求质因数
for(int i=1;i<=cnt&&prime[i]*prime[i]<=n;i++){
int p=prime[i],num=0;
if(n%p==0){
while(n%p==0) n/=p,num++;
mp[p]+=num;
}
}
if(n>1) mp[n]++;
}
int C[105][105]; //组合数
signed main(){
ios::sync_with_stdio(false);
cin.tie(0);Euler();
for(int i=0;i<105;i++) C[i][0]=1;
for(int i=1;i<105;i++){ //预处理组合数
for(int j=1;j<=i;j++){
C[i][j]=(C[i-1][j]+C[i-1][j-1])%mod;
}
}
int n;
while(cin>>n){
mp.clear();
for(int i=1;i<=n;i++) cin>>a[i],solve(a[i]);
int ans=1;
for(auto v:mp){ //求出ai没有限制时的方案数
ans=(ans*C[v.second+n-1][n-1])%mod;
}
for(int i=1;i<n;i++){ //容斥减去ai=1的方案
int tmp=C[n][i];
for(auto v:mp){
tmp=tmp*C[v.second+n-1-i][n-1-i]%mod;
}
ans=(ans+(i&1?-1:1)*tmp)%mod;
}
cout<<(ans+mod)%mod<<endl;
}
return 0;
}
HDU-4190-Number Sequence-容斥原理+多重集和的r组合的更多相关文章
- HDU 4390 Number Sequence 容斥原理
Number Sequence Time Limit: 10000/3000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
- HDU 1711 Number Sequence(数列)
HDU 1711 Number Sequence(数列) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- HDU 1005 Number Sequence(数列)
HDU 1005 Number Sequence(数列) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...
- HDU 1005 Number Sequence(数论)
HDU 1005 Number Sequence(数论) Problem Description: A number sequence is defined as follows:f(1) = 1, ...
- HDU 1711 Number Sequence (字符串匹配,KMP算法)
HDU 1711 Number Sequence (字符串匹配,KMP算法) Description Given two sequences of numbers : a1, a2, ...... , ...
- HDU - 1005 Number Sequence 矩阵快速幂
HDU - 1005 Number Sequence Problem Description A number sequence is defined as follows:f(1) = 1, f(2 ...
- HDU 4390 Number Sequence (容斥原理+组合计数)
HDU 4390 题意: 大概就是这样.不翻译了: Given a number sequence b1,b2-bn. Please count how many number sequences a ...
- HDU 1005 Number Sequence【多解,暴力打表,鸽巢原理】
Number Sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- HDU 1711 Number Sequence(KMP裸题,板子题,有坑点)
Number Sequence Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
随机推荐
- ehcache和redis的区别及适用场景
区别: (1)Redis 独立程序,是通过socket访问到缓存服务,效率比ecache低,比数据库要快很多,处理集群和分布式缓存方便,有成熟的方案 (2)Ehcache 直接在jvm虚拟机中缓存,速 ...
- Spring boot后台搭建二集成Shiro权限控制
上一篇文章,实现了用户验证 查看,接下来实现下权限控制 权限控制,是管理资源访问的过程,用于对用户进行的操作授权,证明该用户是否允许进行当前操作,如访问某个链接,某个资源文件等 Apache Shir ...
- Django文档阅读之执行原始SQL查询
Django提供了两种执行原始SQL查询的方法:可以使用Manager.raw()来执行原始查询并返回模型实例,或者可以完全避免模型层直接执行自定义SQL. 每次编写原始SQL时都要关注防止SQL注入 ...
- POJ1166 The Clocks (爆搜 || 高斯消元)
总时间限制: 1000ms,内存限制: 65536kB 描述 |-------| |-------| |-------| | | | | | | | |---O | |---O | | O | | | ...
- Maven 相关知识点解释
在PC端上面关于Maven的安装等情况我这里就不再复述了,不懂的请自行百度谷歌. 今天聊一下Maven 里面的结构,及相关依赖解释. groupId,artfactId,version,type,cl ...
- sql joins 7
sql joins 7
- [Oracle] - 查看数据库中每个表占用空间大小,及进行表压缩
查询用户创建的表 select * from user_tab_comments; -- 查询本用户的表,视图等. select * from user_col_comments; -- 查询本用户的 ...
- java接入微信JS-SDK
在微信公众号开发中不可,jssdk的接入虽然不是必须,但是根据业务需求我们还是可能用到,下面是自己整理的关于java接入的jssdk的方法,这里是记录关于接入微信JS-SDK的准备工作,关于接入JS- ...
- werkzeug.routing.BuildError: Could not build url for endpoint 'index'. Did you mean 'user.index' instead?
werkzeug.routing.BuildError: Could not build url for endpoint 'index'. Did you mean 'user.index' ins ...
- java.lang.IllegalArgumentException: Expected authority at index 7: http:// 异常的原因
今天遇到个错误,异常信息 java.lang.IllegalArgumentException: Expected authority at index 7: http:// ,中文意思就是说参数 ...