以下资料摘自 http://www.cnblogs.com/wally/archive/2012/07/13/hdu1028_1085_1171_.html

生成函数是说,构造这么一个多项式函数g(x),使得x的n次方系数为f(n)。

对于母函数,看到最多的是这样两句话:

1.“把组合问题的加法法则和幂级数的乘幂对应起来。”

2.“把离散数列和幂级数一 一对应起来,把离散数列间的相互结合关系对应成为幂级数间的运算关系,最后由幂级数形式来确定离散数列的构造。 “

例子:

有1克、2克、3克、4克砝码各一枚,问能称出哪几种重量?每种重量各有几种方案?

下面是用母函数解决这个问题的思路:

首先,我们用X表示砝码,X的指数表示砝码的重量。那么,如果用函数表示每个砝码可以称的重量,

1个1克的砝码可以用函数X^0 + X^1表示,

1个2克的砝码可以用函数X^0 + X^2表示,

依次类推。

如果我们把上面2个多项式相乘,可以得到X^0 + X^1 + X^2 + X^3。继续把它与X^0 + X^3相乘,得到X^0 + X^1 + X^2 + 2*X^3 + X^4 + X^5 + X^6。

接着把它与X^0+X^4相乘,最后得到X^0 + X^1 + X^2 + 2*X^3 + 2*X^4 + 2*X^5 + 2*X^6 + 2*X^7 + X^8 + X^9 + X^10。

由于X的指数表示的是重量,所以,在相乘时,根据幂的运算法则(同底幂相乘,指数相加),得到的结果正是所有的方案。而且,每个X前面的系数代表它有几种方案。

需要注意的是,如果有2个1克的砝码,应该用X^0 + X^1 + X^2表示,而不是X^0 + 2*X^1。

母函数还可以解决其他问题,比如,整数划分。

整数划分是个很经典的问题,划分规则就不再细述,直接说思路。与上面的问题相比,每种砝码的个数不再是1个,而是无限个。于是,

1克的砝码可以用X^0 + X^1 + X^2 + X^3 ……表示,

2克的砝码可以用X^0 + X^2 + X^4 + X^6……表示,

3克的砝码可以用X^0 + X^3 + X^6 + X^9……表示,

依次类推。

相乘后求出X^n的系数,就是结果。

总而言之,解决此类问题,只要模拟好2个多项式相乘就好了。

大概思路是开2个数组,c1[ ]保存当前得到的多项式各项系数,c2[ ]保存每次计算时的临时结果,当每次计算完毕后,把它赋给c1,然后c2清零。

计算的时候,开3层for循环。最外层,记录它正在与第几个多项式相乘。第二层,表示c1中的每一项,第三层表示后面被乘多项式中的每一项。

hdu 1028 整数分解【模板】:

 #include<iostream>
#include<cstdio>
using namespace std;
const int lmax=;
int c1[lmax],c2[lmax];
//G(x)=(1+x+x^2+x^3+...)*(1+x^2+x^4+...)*(1+x^3+x^6+...)+..
int main()
{
int n;
while(cin>>n)
{
for(int i=;i<=n;i++)
{
c1[i]=;//用来保存当前得到的多项式的各项系数
c2[i]=;//用来保存每次计算时的临时结果
}
for(int i=;i<=n;i++)//记录c1正在与第几个多项式进行运算
{
for(int j=;j<=n;j++)//c1中的每一项前的系数
{
for(int k=;k+j<=n;k+=i)//表示被乘多项式的每一项的系数
{
c2[k+j]+=c1[j];//每计算一次并把它赋给用于临时保存数据的c2
}
}
for(int j=;j<=n;j++)
{
c1[j]=c2[j];//每次计算完毕后,就把它赋给c1
c2[j]=;//然后c2清零
}
}
cout<<c1[n]<<endl;
}
}

HDOJ1085:Holding Bin-Laden Captive!

这题WA了几次后发现,是在特殊处理时候不到位导致的= = ,比如:

input:

output:

这是错的= = 应该为:

input:

output:

自己按照模板打的代码:

 #include <stdio.h>
#include <string.h> int main(){
int i,j,x,y,z,max,min;
int c1[],c2[];
while(EOF != scanf("%d%d%d",&x,&y,&z)){
max = x + * y + * z;
min = max+;
if(x == && y == && z == ) break;
memset(c1,,sizeof(c1));
memset(c2,,sizeof(c2));
for(i=;i<=x;i++)
c1[i] = ;
for(i=; i<=x; i++)
for(j=; j<=y*; j+=)
c2[j+i] += c1[i];
for(i=;i<=x+*y;i++){
c1[i] = c2[i];
c2[i] = ;
}
for(i=; i<=x+*y;i++)
for(j=; j<=z*; j+=)
c2[j+i] += c1[i];
for(i=;i<=x+*y+*z;i++){
c1[i] = c2[i];
c2[i] = ;
}
for(i=;i<=max;i++){
if(c1[i] == ){
min = i;
break;
}
}
printf("%d\n",min);
}
return ;
}

【集训笔记】母函数【母函数模板】【HDOJ1028【HDOJ1085的更多相关文章

  1. opencv笔记4:模板运算和常见滤波操作

    time:2015年10月04日 星期日 00时00分27秒 # opencv笔记4:模板运算和常见滤波操作 这一篇主要是学习模板运算,了解各种模板运算的运算过程和分类,理论方面主要参考<图像工 ...

  2. 微信小程序开发:学习笔记[2]——WXML模板

    微信小程序开发:学习笔记[2]——WXML模板 快速开始 介绍 WXML 全称是 WeiXin Markup Language,是小程序框架设计的一套标签语言,结合小程序的基础组件.事件系统,可以构建 ...

  3. 母函数&&排列(模板)

    #include <iostream> #include <algorithm> using namespace std; int main() { int n,i; int ...

  4. hdu 1028 Ignatius and the Princess III(母函数入门+模板)

    Description "Well, it seems the first problem is too easy. I will let you know how foolish you ...

  5. 【集训笔记】【大数模板】特殊的数 【Catalan数】【HDOJ1133【HDOJ1134【HDOJ1130

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3324 http://blog.csdn.net/xymscau/artic ...

  6. django笔记-模型数据模板呈现过程记录(多对多关系)

    首先,推荐一个网址:http://www.tuicool.com/articles/BfqYz2F,因为这里的比我的要有条理,更有利于各位的理解. 以下仅为为个人一次不完整的笔记: 环境:ubuntu ...

  7. AMQ学习笔记 - 05. 客户端模板化

    概述 客户端编程模型中,大部分的步骤都是相同的.将相同的部分做成模板,将不同的部分预留接口,实现者就只需要针对不同的部分提供实现. 设计 类图 发送方客户端 说明: 基于模板的思想,SendTempl ...

  8. Django笔记&教程 3-1 模板(Template)基础

    Django 自学笔记兼学习教程第3章第1节--模板(Template)基础 点击查看教程总目录 1 介绍 模板文件:让Django能够自动生成html代码 作为一个web框架,Django需要需要在 ...

  9. Django笔记&教程 3-2 模板语法介绍

    Django 自学笔记兼学习教程第3章第2节--模板语法介绍 点击查看教程总目录 参考:https://docs.djangoproject.com/en/2.2/topics/templates/# ...

随机推荐

  1. IOS 学习笔记(2) 视图UINavigationController

    1.栈 导航控制器自身有一个针对显示内容的栈,也有一个对于导航栏的栈,当有新的内容欲显示时,进的导航栏和显示内容会被压入此栈,这样原本显示中的导航栏和显示内容则会进入到栈的更深一层中,根据栈的先进后出 ...

  2. mybatis优化配置

    在src下建立db.properties driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/mybatis name=root ...

  3. OSG项目经验2<在场景中添加文字面版>

    添加文字版需要用到osg的三个名字空间:                         osgText::Text,这个类用来添加文字和设置文字的一些属性:                     ...

  4. PROTEL99生成GERBER的操作说明

    GBL BOTTOM LAYER(底层布线图)GBO BOTTOM OVERLAYER(底层丝印层)GBP BOTTOM PASTE LAYER(底层锡膏层)GBS BOTTOM SOLDER MAS ...

  5. Ubuntu Linux: How Do I install .deb Packages?

    Ubuntu Linux: How Do I install .deb Packages? Ubuntu Linux: How Do I install .deb Packages? by Nix C ...

  6. hpu校赛--雪人的高度(离散化线段树)

    1721: 感恩节KK专场——雪人的高度 时间限制: 1 Sec  内存限制: 128 MB 提交: 81  解决: 35 [提交][状态][讨论版] 题目描述 大雪过后,KK决定在春秋大道的某些区间 ...

  7. Android 中文API (65) —— BluetoothClass[蓝牙]

    前言 本章内容是android.bluetooth.BluetoothClass,为Android蓝牙部分的章节翻译.用于描述远端设备的类型,特点等信息,通过getBluetoothClass()方法 ...

  8. 记载abp中Dbcontext的疑问

    q:abp中httpcontext如何在一次请求中保证获取的是相同的实例. 大牛的原话: LifestylePerWebRequest does not works good with async. ...

  9. An Introduction to Interactive Programming in Python

    这是在coursera上面的一门学习pyhton的基础课程,由RICE的四位老师主讲.生动有趣,一共是9周的课程,每一周都会有一个小游戏,经历一遍,对编程会产生很大的兴趣. 所有的程序全部在老师开发的 ...

  10. MVC+ADO模式

    MVC+DAO设计模式 博客分类: Java Java WEB开发   MVC+DAO设计模式 本文摘自:http://www.paper.edu.cn    基于MVC+DAO设计模式的Struts ...