找单词

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 5782    Accepted Submission(s): 4062

Problem Description
如果有x1个字母A。 x2个字母B,..... x26个字母Z。同一时候如果字母A的价值为1。字母B的价值为2,..... 字母Z的价值为26。那么,对于给定的字母。能够找到多少价值<=50的单词呢?单词的价值就是组成一个单词的全部字母的价值之和,比方,单词ACM的价值是1+3+14=18,单词HDU的价值是8+4+21=33。(组成的单词与排列顺序无关,比方ACM与CMA觉得是同一个单词)。
 
Input
输入首先是一个整数N。代表測试实例的个数。

然后包含N行数据,每行包含26个<=20的整数x1,x2,.....x26.

 
Output
对于每一个測试实例。请输出能找到的总价值<=50的单词数,每一个实例的输出占一行。
 
Sample Input
2
1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
9 2 6 2 10 2 2 5 6 1 0 2 7 0 2 2 7 5 10 6 10 2 10 6 1 9
 
Sample Output
7
379297
 
Source

field=problem&key=2006%2F1%2F15+ACM%B3%CC%D0%F2%C9%E8%BC%C6%C6%DA%C4%A9%BF%BC%CA%D4&source=1&searchmode=source" style="color:rgb(26,92,200); text-decoration:none">2006/1/15 ACM程序设计期末考试

知识点:

母函数(生成函数):

生成函数有普通型生成函数和指数型生成函数两种(本题是普通型)。

形式上,普通型母函数用于解决多重集的组合问题,

指数型母函数用于解决多重集的排列问题。

母函数还能够解决递归数列的通项问题(比如使用母函数解决斐波那契数列,Catalan数的通项公式)。

普通母函数:

构造母函数G(x), G(x) = a0 + a1*x + a2* +
a3* +....+
an*。 
则称G(x)是数列a0,a1…an的母函数。

通常普通母函数用来解多重集的组合问题,其思想就是构造一个函数来解决这个问题。一般步骤例如以下:

1.建立模型:物品n种,每种数量分别为k1,k2,..kn个,每种物品又有一个属性值p1,p2,…pn,(如本题的字母价值),

求属性值和为m的物品组合方法数。

(若数量ki无穷
也成立。即相应以下式子中第ki项的指数一直到无穷)

2.构造母函数:G(x)=(1++)(1+++…)…(1+++…)       
(一)

=a0 + a1*x + a2* +
a3* +....+
akk*    
(设kk=k1·p1+k2·p2+…kn·pn)  (二)

G(x)含义: ak 为属性值和为k的组合方法数。

母函数利用的思想:

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

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

确定离散数列的构造。

代码实现:

求G(x)时一项一项累乘。先令G=1=(1+0*x+0*+…0*),再令G=G*(1++)得到形式(二)的式子…最后令G=G*(1+++…)。

题解:

1.建模:物品(字母)26种,每种数量x1,x2…x26。属性值为1,2,3..26,求属性值和<=50的组合方法数。

2.G(x)=(1++)(1+++…)…(1++…)

#include <iostream>

#include <algorithm>

#include <stdio.h>

#include <string.h>





using namespace std;

int c1[100],c2[100];

int a[30];

int main()

{

    int t;

    cin >> t;

    while(t --)

    {

        for(int i = 1; i <= 26; i ++)

            cin >> a[i];

        memset(c1,0,sizeof(c1));

        memset(c2,0,sizeof(c2));

        c1[0] = 1;///初始化

        for(int i = 1; i <= 26; i ++)///相应26个多项式

        {

            for(int j = 0; j <= 50; j ++)   ///每一个多项式中相应的指数

                for(int k = 0; k <= a[i] && k * i + j <= 50; k ++)  ///k*i表示被乘多项式各项的指数

                    c2[j + k * i] += c1[j];

            memcpy(c1,c2,sizeof(c2));///c2数组的值赋值给c1

            memset(c2,0,sizeof(c2));///c2初始化

        }

        ///累加

        int sum = 0;

        for(int i = 1; i <= 50; i ++)

            sum += c1[i];

        cout << sum << endl;

    }

    return 0;

}

HDU2082母函数模板题的更多相关文章

  1. HDU 2079 选课时间(母函数模板题)

    链接:传送门 思路:母函数模板题 /************************************************************************* > Fil ...

  2. hdu1521 排列组合 指数型母函数模板题

    排列组合 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  3. HDU1028 Ignatius and the Princess III 【母函数模板题】

    Ignatius and the Princess III Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K ...

  4. HDU 2082 母函数模板题

    找单词 Time Limit: 1000MS   Memory Limit: 32768KB   64bit IO Format: %I64d & %I64u Submit Status De ...

  5. hdu2082 找单词 母函数模板

    找单词 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  6. [AHOI 2009] 维护序列(线段树模板题)

    1798: [Ahoi2009]Seq 维护序列seq Time Limit: 30 Sec  Memory Limit: 64 MB Description 老师交给小可可一个维护数列的任务,现在小 ...

  7. HDU 2222 AC自动机模板题

    题目: http://acm.hdu.edu.cn/showproblem.php?pid=2222 AC自动机模板题 我现在对AC自动机的理解还一般,就贴一下我参考学习的两篇博客的链接: http: ...

  8. POJ2774 & 后缀数组模板题

    题意: 求两个字符串的LCP SOL: 模板题.连一起搞一搞就好了...主要是记录一下做(sha)题(bi)过程心(cao)得(dan)体(xin)会(qing) 后缀数组概念...还算是简单的,过程 ...

  9. HDU 1251 Trie树模板题

    1.HDU 1251 统计难题  Trie树模板题,或者map 2.总结:用C++过了,G++就爆内存.. 题意:查找给定前缀的单词数量. #include<iostream> #incl ...

随机推荐

  1. HDU 1022 火车进站【栈】

     题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1022 题目大意: 题目大概意思:有N辆火车,以序列1方式进站,判断是否能以序列2方式出栈.进站不一定 ...

  2. P3258 [JLOI2014]松鼠的新家

    P3258 [JLOI2014]松鼠的新家倍增lca+树上差分,从叶子节点向根节点求前缀和,dfs求子树和即可,最后,把每次的起点和终点都. #include<iostream> #inc ...

  3. docker+springboot+elasticsearch+kibana+elasticsearch-head整合(详细说明 ,看这一篇就够了)

    一开始是没有打算写这一篇博客的,但是看见好多朋友问关于elasticsearch的坑,决定还是写一份详细的安装说明与简单的测试demo,只要大家跟着我的步骤一步步来,100%是可以测试成功的. 一.  ...

  4. bootstrap图片轮播

    <div class="carousel slide" id="myCarsousel" style="width:790px;"&g ...

  5. AE 模板 素材 视频 科技 公安

    3d立体现代城市模型背景视频素材视频素材下载__熊猫办公 1080p 科技高速公路汽车奔驰背景视频视频素材下载__熊猫办公 高科技hud全息元素素材ae视频素材下载__熊猫办公 渲染输出,Adobe ...

  6. 洛谷P1309 瑞士轮(归并排序)

    To 洛谷.1309 瑞士轮 题目背景 在双人对决的竞技性比赛,如乒乓球.羽毛球.国际象棋中,最常见的赛制是淘汰赛和循环赛.前者的特点是比赛场数少,每场都紧张刺激,但偶然性较高.后者的特点是较为公平, ...

  7. 数据库——MongoDB的安装

    1.进入到 /usr/local/ 目录: 1 cd /usr/local 2.安装必要插件 yum -y install gcc make gcc-c++ openssl-devel wget yu ...

  8. fetch添加超时时间

    fetch添加超时时间 其实为fetch添加超时时间很简单,需要用到Promise.race()方法. Promise.race() 方法将多个Promise包装成一个新的Promise实例. var ...

  9. Markdown 的离线编辑工具推荐:Sublime Text3 or Typora?我推荐Typora

    最新版Sublime Text3 通过插件的方式,可以完美支持Markdown文档的编写,但是,唯一不完美的是实时预览的缺陷.可能各位看官要喷了,谁说Sublime Text3 不能实时预览的?你看: ...

  10. 防止APACHE解析漏洞

    一.PHP端,规范代码,加强尾缀验证 二.Apache端,在httpd.conf中加上如下代码: <Files~"\.(p|P)(h|H)(p|P)."> Deny f ...