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】

  1. #include<iostream>
  2. #include<algorithm>
  3. #include<map>
  4. #include<cstring>
  5. #include<cstdio>
  6. using namespace std;
  7. #define INF 0x3f3f3f3f
  8. #define maxn 1000005
  9. #define int long long
  10. const int mod=1e9+7;
  11. int a[25];
  12. int prime[maxn],cnt=0;
  13. bool vis[maxn]={1,1};
  14. void Euler(){ //欧拉筛
  15. for(int i=2;i<maxn;i++){
  16. if(!vis[i]) prime[++cnt]=i;
  17. for(int j=1;j<=cnt&&i*prime[j]<maxn;j++){
  18. vis[i*prime[j]]=1;
  19. if(i%prime[j]==0) break;
  20. }
  21. }
  22. }
  23. map<int,int>mp; //统计每个质因数出现的次数
  24. void solve(int n){ //求质因数
  25. for(int i=1;i<=cnt&&prime[i]*prime[i]<=n;i++){
  26. int p=prime[i],num=0;
  27. if(n%p==0){
  28. while(n%p==0) n/=p,num++;
  29. mp[p]+=num;
  30. }
  31. }
  32. if(n>1) mp[n]++;
  33. }
  34. int C[105][105]; //组合数
  35. signed main(){
  36. ios::sync_with_stdio(false);
  37. cin.tie(0);Euler();
  38. for(int i=0;i<105;i++) C[i][0]=1;
  39. for(int i=1;i<105;i++){ //预处理组合数
  40. for(int j=1;j<=i;j++){
  41. C[i][j]=(C[i-1][j]+C[i-1][j-1])%mod;
  42. }
  43. }
  44. int n;
  45. while(cin>>n){
  46. mp.clear();
  47. for(int i=1;i<=n;i++) cin>>a[i],solve(a[i]);
  48. int ans=1;
  49. for(auto v:mp){ //求出ai没有限制时的方案数
  50. ans=(ans*C[v.second+n-1][n-1])%mod;
  51. }
  52. for(int i=1;i<n;i++){ //容斥减去ai=1的方案
  53. int tmp=C[n][i];
  54. for(auto v:mp){
  55. tmp=tmp*C[v.second+n-1-i][n-1-i]%mod;
  56. }
  57. ans=(ans+(i&1?-1:1)*tmp)%mod;
  58. }
  59. cout<<(ans+mod)%mod<<endl;
  60. }
  61. return 0;
  62. }

HDU-4190-Number Sequence-容斥原理+多重集和的r组合的更多相关文章

  1. HDU 4390 Number Sequence 容斥原理

    Number Sequence Time Limit: 10000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  2. HDU 1711 Number Sequence(数列)

    HDU 1711 Number Sequence(数列) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...

  3. HDU 1005 Number Sequence(数列)

    HDU 1005 Number Sequence(数列) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...

  4. HDU 1005 Number Sequence(数论)

    HDU 1005 Number Sequence(数论) Problem Description: A number sequence is defined as follows:f(1) = 1, ...

  5. HDU 1711 Number Sequence (字符串匹配,KMP算法)

    HDU 1711 Number Sequence (字符串匹配,KMP算法) Description Given two sequences of numbers : a1, a2, ...... , ...

  6. HDU - 1005 Number Sequence 矩阵快速幂

    HDU - 1005 Number Sequence Problem Description A number sequence is defined as follows:f(1) = 1, f(2 ...

  7. HDU 4390 Number Sequence (容斥原理+组合计数)

    HDU 4390 题意: 大概就是这样.不翻译了: Given a number sequence b1,b2-bn. Please count how many number sequences a ...

  8. HDU 1005 Number Sequence【多解,暴力打表,鸽巢原理】

    Number Sequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)T ...

  9. HDU 1711 Number Sequence(KMP裸题,板子题,有坑点)

    Number Sequence Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

随机推荐

  1. nginx启动命令以及与配置systemctl

    一.配置systemctl之前的启动方式 进入sbin目录下执行以下命令: 启动nginx的命令为 /usr/local/nginx/sbin/nginx 3 停止nginx的命令为 /usr/loc ...

  2. Apache新的URL路由重写规则

    在根目录下新建一个 .htaccess 后缀文件,将下面代码放进去即可 <IfModule mod_rewrite.c> Options +FollowSymlinks -Multivie ...

  3. /x86_64-linux-gnu/libSM.so: undefined reference to `uuid_generate@UUID_1.0'错误

    在编译PCL的时候总是报错,其他人都没问题 后来发现是我cmakePCL的时候,QT引用的是anaconda里的qt,把这个一改果然没问题了,耽误了一天时间. 感谢stack上这位老铁

  4. MySQL 中的共享锁和排他锁的用法

    在 MySQL 中的行级锁.表级锁和页级锁中,咱们介绍过,行级锁是 MySQL 中锁定粒度最细的一种锁,行级锁能大大减少数据库操作的冲突.行级锁分为共享锁和排他锁两种,本文将详细介绍共享锁和排他锁的概 ...

  5. 【vim小记】自动保存配置

    刚接触vim会发现有很多不习惯,其中,不能自动保存当前配置,每次退出要重新配置,很麻烦,好在vim早就为我们想到这些,在看手册的时候,发现里面有session,  这是用户手册的介绍: “会话保存所有 ...

  6. 《Mysql - 自增主键为何不是连续的?》

    一:自增主键是连续的么? - 自增主键不能保证连续递增. 二:自增值保存在哪里? - 当使用 show create table `table_name`:时,会看到 自增值,也就是 AUTO_INC ...

  7. (idea maven)mybatis-generator步骤

    1.新建一个maven项目,选择maven-archetype-webapp 点击next 2.项目名称,点击next 3.选择项目存放路径,然后点击finish 4.在main包下 添加包java和 ...

  8. Nvidia Jetson TX2开发板学习历程(1)- 详细开箱、上电过程

    考试周已经结束了,开发板也已经到了.希望借着这个假期能够好好的利用这块开发板学习Linux系统以及Tensorflow的相关知识. 我打算将学习历程通过博客的方式写出来,作为自己的笔记,也可以供以后拿 ...

  9. json转义问题

    后端程序接受前台传递过来json 1正常json没有问题 比如  {"id":21,"userName":"2张天师","phon ...

  10. golang面对接口