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. H+后台主题UI框架---整理(三)

    这里面介绍下H+后台主题UI框架里面插件的应用,不过都是最最简单最初级的功能.主要有日历插件,input单选多选(icheck)插件,input下拉搜索(chosen)插件. 一.日历插件 有如下几种 ...

  2. re正则表达式公式讲解6

    标识符 re.I (re.IGNORECASE) 忽略大小写 import re s = "Max@123uyt146" print(re.search("m" ...

  3. js操作css样式、js的兼容问题

    一.js操作css样式 div . style . width="200px" 在div标签内我们添加了一个style属性,并设定width值.这种写法会给标签带来大量的style ...

  4. ES6学习笔记(11)----Proxy

    参考书<ECMAScript 6入门>http://es6.ruanyifeng.com/ Proxy1.概述    Proxy可以用来修改对象的默认操作    let obj = {na ...

  5. java 获取ip地址

    1.使用WIFI 首先设置用户权限 <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"& ...

  6. 秦晓波著的编写高质量代码-改善Java程序的151个建议一书中的线程解释错误.

    位置: 建议127: Lock与synchronized是不一样的 首先在概念上纠正这一篇内容: 援引Java源码中关于ReentrantLock的开篇说明: * A reentrant mutual ...

  7. laravel中的队列

    Laravel 队列为不同的后台队列服务提供统一的 API,可使用多种驱动,eg:mysql,redis,Beanstalkd等,驱动已经封装,不需要管理这些驱动,只需要修改配置就可以更改驱动,在驱动 ...

  8. CSV解析

    NSString *path = [[NSBundle mainBundle] pathForResource: @"type" ofType:@"csv"]; ...

  9. 回顾Spring MVC_01_概述_入门案例

    SpringMVC: SpringMVC是Spring为展现层提供的基于MVC设计的优秀的Web框架,是目前最主流的MVC框架之一 SpringMVC通过注解,让POJO成为处理请求的控制器,而无须实 ...

  10. CortexA7工业级迅为-iMX6UL开发板硬件和资料介绍

    商业级核心板 ARM Cortex-A7架构 主频高达528 MHz 核心板512M DDR内存 8G EMMC 存储 运行温度:-20℃ ~ +80℃ CPU集成电源管理 核心板尺寸仅:42mm*3 ...