HDU 4651 Partition

Problem :

n的整数划分方案数。(n <= 100008)

Solution :

参考资料:

五角数 欧拉函数 五边形数定理 整数划分 一份详细的题解

欧拉函数的定义如下:

\[\phi(q) =\prod\limits_{n=1}^{\infty}(1-q^n)
\]

五边形定理对欧拉函数展开如下:

\[\phi(q) = \sum_{n = 0}^{n = \infty}(-1)^nq^{\frac{3n^2\pm n}{2}}
\]

其中 \(\frac{3n^2\pm n}{2}\)为广义五边形数。

而欧拉函数的倒数为

\[\frac{1}{\phi(q)} = \prod\limits_{n = 1}^{\infty} \frac{1}{1-q^k}
\]

\[\frac{1}{\phi(q)} = (1 + q + q ^2 + \cdots)(1 + q ^ 2 + q ^ 4 + \cdots)(1 + q ^ 3 + q ^ 6 + \cdots)'\cdots
\]

\[\frac{1}{\phi(q)}= \sum_{n =0}^{\infty}P(q) q^n
\]

其中P(q)即为q的整数划分方案数,可以从展开式的意义考虑,对于第一个括号表示1取几个,第二个括号表示2取几个,以此类推。

将上下两个式子相乘即得到

\[\sum_{n =0}^{\infty}P(q) q^n * \sum_{n = 0}^{n = \infty}(-1)^nq^{\frac{3n^2\pm n}{2}} = 1
\]

\[(1 + P(1) * q + P(2) * q^2 + P(3) * q ^ 2 + \cdots)(1 - q - q ^ 2 + q ^ 5 + \cdots) = 1
\]

展开可得到

\[P(n) = \sum_{i = 1} (-1)^{i -1} P(n - \frac{3*i^2 \pm i}{2})
\]

其中要保证括号内的数大于等于0.

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <string>
#include <map> using namespace std; const int N = 1e5 + 8;
const int mo = 1e9 + 7; int dp[N]; int main()
{
cin.sync_with_stdio(0);
int n = 1e5;
dp[0] = 1;
for (int i = 1; i <= n; ++i)
{
for (int j = 1, tmp = 1; i >= (3 * j * j - j) / 2; ++j, tmp *= -1)
{
int x = (3 * j * j - j) / 2;
int y = (3 * j * j + j) / 2;
dp[i] = ((dp[i] + tmp * dp[i - x]) % mo + mo) % mo;
if (i >= y) dp[i] = ((dp[i] + tmp * dp[i - y]) % mo + mo) % mo;
}
}
int T; cin >> T;
while (T--)
{
int n; cin >> n;
cout << dp[n] << endl;
}
}

HDU 4651 (生成函数)的更多相关文章

  1. hdu 4651 Partition (利用五边形定理求解切割数)

    下面内容摘自维基百科: 五边形数定理[编辑] 五边形数定理是一个由欧拉发现的数学定理,描写叙述欧拉函数展开式的特性[1] [2].欧拉函数的展开式例如以下: 亦即 欧拉函数展开后,有些次方项被消去,仅 ...

  2. HDU 4651 Partition(整数拆分)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4651 题意:给出n.求其整数拆分的方案数. i64 f[N]; void init(){    f[0 ...

  3. hdu - 4651 - Partition

    题意:把一个整数N(1 <= N <= 100000)拆分不超过N的正整数相加,有多少种拆法. 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid ...

  4. hdu 4651 Partition && hdu 4658 Integer Partition——拆分数与五边形定理

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=4651 参考:https://blog.csdn.net/u013007900/article/detail ...

  5. hdu 1028 && hdu 1398 && hdu 1085 && hdu 1171 ——生成函数

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1028 就是可以用任意个1.2.3....,所以式子写出来就是这样:(1+x+x^2+...)(1+x^2+ ...

  6. HDU 1171 Big Event in HDU --暴力+生成函数

    题意:给n种房子,每种房子有一个值val和个数cnt,现在要把这些房子分成两部分,争取两部分总值相等,如果不能相等,让A>B,且A-B最小. 解法:先跑一次生成函数,c[n]表示组成总值为n的方 ...

  7. hdu 2082 生成函数

    主题链接:http://acm.hdu.edu.cn/showproblem.php?pid=2082 找单词 Time Limit: 1000/1000 MS (Java/Others)    Me ...

  8. Ignatius and the Princess III HDU - 1028 -生成函数or完全背包计数

    HDU - 1028 step 1:初始化第一个多项式 也就是 由 1的各种方案 组 成 的多项式 初始化系数为 1.临时区 temp初始化 为 0 step 2:遍历后续的n - 1 个 多项式 , ...

  9. hdu 1171 Big Event in HDU【生成函数】

    按套路列生成函数式子然后暴力乘,这样复杂度看起来非常大,但是可以动态维护最大值,这样就是O(能过)的了 仔细想想这个多项式暴力乘理解成背包dp也行? #include<iostream> ...

随机推荐

  1. leetcode410 Split Array Largest Sum

    思路: dp. 实现: class Solution { public: int splitArray(vector<int>& nums, int m) { int n = nu ...

  2. 获得select被选中option的value和text

    一:JavaScript原生的方法 1:得到select对象: var myselect=document.getElementById(“test”); 2:得到选中项的索引:var index=m ...

  3. android开发中设置字体

    转自:http://segmentfault.com/q/1010000000494116 http://ryanhoo.github.io/blog/2014/05/05/android-bette ...

  4. learnpythonthehardway EX41 相关

    str.count() # str.count()方法用于统计字符串里某个字符出现的次数.可选参数为在字符串搜索的开始与结束位置. # str.count(sub, start= 0,end=len( ...

  5. iOS端架构、基本组成与使用说明

    一. app整体描述 app的描述:需求文档+接口文档+程序架构. 说明:新入手的开发人员必须拿到这三个说明文档才能整体了解app功能. 二.app架构描述 1.架构视图 2.分层结构说明 [1] a ...

  6. select2宽度占比100%,导致无法实现浮动效果

  7. 目录下 shift 右键菜单 打开cmd 或者在 地址栏输入cmd 回车进入cmd

    目录下 shift 右键菜单 打开cmd 或者在 地址栏输入cmd 回车进入cmd

  8. project .mpp 查看当天工作任务 1.选择自己 2.选择起始和终止时间 就显示当天的任务了

    project .mpp 查看当天工作任务 1.选择自己 2.选择起始和终止时间 就显示当天的任务了

  9. centOS7安装 mysql-community-release-el7-5.noarch.rpm 包

    一.rpm包 1.wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm(下载rpm) 2.rpm -ivh mysql ...

  10. SQL比较两表字段和字段类型

    一.问题 业务需要把TB_Delete_KYSubProject表数据恢复到TB_KYSubProject,但提示错误,错误原因是两表字段类型存在不一致 insert into [TB_KYSubPr ...