普通型母函数和指数型母函数

2024-02-19 14:38
文章标签 函数 指数 型母 普通型

本文主要是介绍普通型母函数和指数型母函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

母函数:摘自百度百科

生成函数即母函数,是组合数学中尤其是计数方面的一个重要理论和工具。生成函数有普通型生成函数和指数型生成函数两种,其中普通型用的比较多。形式上说,普通型生成函数用于解决多重集的组合问题,而指数型母函数用于解决多重集的排列问题。母函数还可以解决递归数列的通项问题(例如使用母函数解决斐波那契数列的通项公式)

理解:

什么是普通母函数呢,——把组合问题的加法法则和幂级数的的乘幂的相加对应起来,这句话可能一开始难以理解,不过其实学完了之后很容易理解,母函数的思想很简单—就是把离散数列和幂级数一一对应起来,把离散数列间的相互结合关系对应成为幂级数间的运算关系,最后由幂级数形式来确定离散数列的构造。

 

        母函数分为:普通型母函数指数型母函数

        普通型母函数主要是来求组合的方案数,而指数型母函数是求多重排列数

普通母函数:

定义

若函数G(x)=a0+a1*x+a2*x^2+……+an*x^n,则称函数G(x)为序列a0、a1、a2、……an的母函数。

 

例如:(1+x)^n=1+C(n,1)*x+C(n,2)*x^2+……+C(n,n)*x^n 就是序列 C(n,1)、C(n,2)、……、C(n,n)的母函数,其中C(n,m)为组合数。

 

经典例题

有质量为1,2,4的砝码分别为1,3,2枚,问:

1.可以称出多少种不同的质量?

2.要称出质量为3的物品,有几种可能的方式?

 

则可以构造函数G(x) = (1+x)*(1+x^2+x^4+x^6)*(1+x^4+x^8),其中第一个括号中的1表示质量为1的砝码用了0枚,x表示质量为1的砝码用了1枚;第二个括号中的1表示质量为2的砝码用了0枚,x^2为质量为2的砝码用了1枚,x^4表示质量为2的砝码用了2枚,也就是x^(2*2),x^6表示质量为2的砝码用了3枚,也就是x^(2*3)。先不必理解为什么这样做,只需要知道怎样做。

 

总结一下,每个括号就表示一种砝码的使用情况。x^n就表示质量为n的砝码用了1枚。最少可以使用0枚,也就是式子里面的1。最多可以使用m枚,也就是x^(n*m)。

 

知道了对应关系,那么代码应该怎么写呢?其实也简单,就是模拟手动计算以上多项式相乘的过程。比如上面的

G(x) = (1+x)*(1+x^2+x^4+x^6)*(1+x^4+x^8)

= (1+x^2+x^4+x^6  + x+x^3+x^5+x^7)*(1+x^4+x^8)

= (1+x+x^2+x^3+x^4+x^5+x^6+x^7)*(1+x^4+x^8)

= (1+x+x^2+x^3+x^4+x^5+x^6+x^7  +  x^4+x^5+x^6+x^7+x^8+x^9+x^10+x^11  +  x^8+x^9+x^10+x^11+x^12+x^13+x^14+x^15)

=1+x+x^2+x^3+2*x^4+2*x^5+2*x^6+2*x^7+2*x^8+2*x^9+2*x^10+2*x^11+x^12+x^13+x^14+x^15

 

以上过程也就是不断的计算前 i 个多项式相乘的结果。最后得到的式子中 m*x^n 就表示可以有m种方式称出质量为n的物品。一共有x~x^15个不同的质量,也就是最多能称出15中不同质量的物品


#define MAXN 55int a[MAXN],b[MAXN];int s[MAXN],e[MAXN],v[MAXN];void mu(int n){ //n为因子个数 int i,j,k;memset(a,0,sizeof(a));a[0]=1;for(i=1;i<=n;i++){ //前i项相乘 memset(b,0,sizeof(b));//j为第i种物品可能的数量,j*v[i]即第i个括号中第j项的系数for(j=s[i];j<=e[i]&&j*v[i]<=MAXN;j++)for(k=0;k+j*v[i]<=MAXN;k++) //计算对前i-1项相乘的结果的第k项的系数产生的影响 b[k+j*v[i]]+=a[k];memcpy(a,b,sizeof(b)); //将b数组存回a数组 }	}

以上代码中MAXN为结果可能生成的x的指数的最大值。

a数组存储最终结果,b数组存储中间结果
s[i] (start数组)为第i个变量的最小个数,一般都为0,e[i] (end数组)为第i个变量的最大个数
v[i]表示第i个未知量的取值,即x^v[i]
a[i]存储的是未知量 x^i 前面的系数

 

也就是a存储前i-1项的相乘结果,然后遍历第i项中的每一个变量,让其与a中的每一项相乘,将结果临时存储到b数组中,最后存回a数组。

 

例如:求不同个数的不同质量的砝码可以组成的质量为 i 的种类数
v[i]存第i种砝码质量,s[i]存第i种砝码最小的个数,e[i]存第i种砝码最大的个数,a[i]存可以组成的质量为i的种类数、

指数函数:

模板:https://blog.csdn.net/SunPeishuai/article/details/81412049

参考:https://blog.csdn.net/agoniangel/article/details/51899372

          https://blog.csdn.net/zuzhiang/article/details/77948274

这篇关于普通型母函数和指数型母函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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>

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

Unity3D 运动之Move函数和translate

CharacterController.Move 移动 function Move (motion : Vector3) : CollisionFlags Description描述 A more complex move function taking absolute movement deltas. 一个更加复杂的运动函数,每次都绝对运动。 Attempts to

✨机器学习笔记(二)—— 线性回归、代价函数、梯度下降

1️⃣线性回归(linear regression) f w , b ( x ) = w x + b f_{w,b}(x) = wx + b fw,b​(x)=wx+b 🎈A linear regression model predicting house prices: 如图是机器学习通过监督学习运用线性回归模型来预测房价的例子,当房屋大小为1250 f e e t 2 feet^

JavaSE(十三)——函数式编程(Lambda表达式、方法引用、Stream流)

函数式编程 函数式编程 是 Java 8 引入的一个重要特性,它允许开发者以函数作为一等公民(first-class citizens)的方式编程,即函数可以作为参数传递给其他函数,也可以作为返回值。 这极大地提高了代码的可读性、可维护性和复用性。函数式编程的核心概念包括高阶函数、Lambda 表达式、函数式接口、流(Streams)和 Optional 类等。 函数式编程的核心是Lambda

PHP APC缓存函数使用教程

APC,全称是Alternative PHP Cache,官方翻译叫”可选PHP缓存”。它为我们提供了缓存和优化PHP的中间代码的框架。 APC的缓存分两部分:系统缓存和用户数据缓存。(Linux APC扩展安装) 系统缓存 它是指APC把PHP文件源码的编译结果缓存起来,然后在每次调用时先对比时间标记。如果未过期,则使用缓存的中间代码运行。默认缓存 3600s(一小时)。但是这样仍会浪费大量C

PHP7扩展开发之函数方式使用lib库

前言 首先说下什么是lib库。lib库就是一个提供特定功能的一个文件。可以把它看成是PHP的一个文件,这个文件提供一些函数方法。只是这个lib库是用c或者c++写的。 使用lib库的场景。一些软件已经提供了lib库,我们就没必要再重复实现一次。如,原先的mysql扩展,就是使用mysql官方的lib库进行的封装。 在本文,我们将建立一个简单的lib库,并在扩展中进行封装调用。 代码 基础