不同种类不同个数集合的重复排列——指数型母函数

2024-03-27 22:58

本文主要是介绍不同种类不同个数集合的重复排列——指数型母函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我们知道多元素的多重集排列是这样的:
元素   个数
a1       n1
a2       n2
a3       n3
……
ak       nk
其中n=n1+n2+……+nk
取出所有的元素,不同的排列情况应该是

当不是取出所有元素呢?
回想母函数的方法:
1g砝码,2g砝码,3g砝码……均有无限个,那么母函数的表达式就是
砝码故事的背景是所有的砝码都是”同类的“,而现在相当于是有不同种类的砝码,问排列情况。从这个角度看,指数型函数的答案应该比普通母函数的答案要大。
事实确实是这样:
最终得到:

答案就是 对应的

应用:
hdu 1521
http://acm.hdu.edu.cn/showproblem.php?pid=1521
大意:有n种物品,并且知道每种物品的数量。要求从中选出m件物品的排列数
#include <iostream>
#include <cstdio>
using namespace std;
int c[15],fac[15];
double c1[15],c2[15];
int main()
{fac[0]=1;for(int i=1;i<=10;i++) fac[i]=fac[i-1]*i;int n,m;while(cin>>n>>m){for(int i=1;i<=n;i++) scanf("%d",&c[i]);for(int i=0;i<15;i++) c1[i]=c2[i]=0.0;for(int i=0;i<=c[1];i++){c1[i]=1.0/fac[i];}for(int i=2;i<=n;i++){for(int j=0;j<=m&&j<=c[i];j++){for(int k=0;k+j<=m;k++){c2[k+j]=c2[k+j]+c1[k]/fac[j];}}for(int j=0;j<=m;j++){c1[j]=c2[j];c2[j]=0;}}printf("%.0lf\n",c1[m]*fac[m]);}return 0;
}


这篇关于不同种类不同个数集合的重复排列——指数型母函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/853678

相关文章

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

poj2406(连续重复子串)

题意:判断串s是不是str^n,求str的最大长度。 解题思路:kmp可解,后缀数组的倍增算法超时。next[i]表示在第i位匹配失败后,自动跳转到next[i],所以1到next[n]这个串 等于 n-next[n]+1到n这个串。 代码如下; #include<iostream>#include<algorithm>#include<stdio.h>#include<math.

poj3261(可重复k次的最长子串)

题意:可重复k次的最长子串 解题思路:求所有区间[x,x+k-1]中的最小值的最大值。求sa时间复杂度Nlog(N),求最值时间复杂度N*N,但实际复杂度很低。题目数据也比较水,不然估计过不了。 代码入下: #include<iostream>#include<algorithm>#include<stdio.h>#include<math.h>#include<cstring

spoj705( 求不相同的子串个数)

题意:求串s的不同子串的个数 解题思路:任何子串都是某个后缀的前缀,对n个后缀排序,求某个后缀的前缀的个数,减去height[i](第i个后缀与第i-1 个后缀有相同的height[i]个前缀)。 代码如下: #include<iostream>#include<algorithm>#include<stdio.h>#include<math.h>#include<cstrin

uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401

题意是求在base进制下的 n!的结果有几位数,末尾有几个0。 想起刚开始的时候做的一道10进制下的n阶乘末尾有几个零,以及之前有做过的一道n阶乘的位数。 当时都是在10进制下的。 10进制下的做法是: 1. n阶位数:直接 lg(n!)就是得数的位数。 2. n阶末尾0的个数:由于2 * 5 将会在得数中以0的形式存在,所以计算2或者计算5,由于因子中出现5必然出现2,所以直接一

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

XTU 1233 n个硬币连续m个正面个数(dp)

题面: Coins Problem Description: Duoxida buys a bottle of MaiDong from a vending machine and the machine give her n coins back. She places them in a line randomly showing head face or tail face o

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip