首页 > 其他 > 详细

[学习笔记]整数划分数

时间:2019-02-17 22:17:27      阅读:308      评论:0      收藏:0      [点我收藏+]

定义

P(i)把i划分成若干个整数的和的方案数。方案数不同当且仅当所用整数排序后不对应相同(存在某个整数用的次数不同)

求法

都是求前n项的每一项

完全背包

O(n^2)

分块背包

根据物品大小分块

小于根号n的只有n种:
f(i,j)前i个,j大小
f(i,j)<-f(i-1,j-sz[i]*k)

后面枚举k用一个前缀和优化

O(nsqrt(n))

大于根号n的最多用根号n个
f(i,j)用了i个,j大小
f(i,j)->f(i+1,j+sqrt(n))

或者集体加1

f(i,j)->f(i,j+i)

道理是,初始认为是sqrt的,增长要靠集体加1,由于是“集体”所以必须操作有先后顺序,使得每个方案都恰好会被枚举到一次

O(nsqrt(n))

把第一维i都去掉(第一个直接去,第二个做前缀和)然后卷积一下即可。

生成函数

五边形数和整数拆分数

技术分享图片

递推整数拆分数方法:

$F(x)\Pi_i(1-x^i)=1$

$F(x)(\sum a_ix^i)=1$

$(\sum a_i f_{n-i} x^i)=1$

观察第n项系数:(第n项系数等式右边是0)

$[x^n]f_n\sum_{i=1}^{n-1} a_i f_{n-i} =0$

再对比五边形数:

$\Pi_i(1-x^i)=(\sum a_ix^i)=\sum_k (-1)^kx^\frac{k(3k+1)}{2}$

由于k也可以为负数,所以,只有当$i=\frac{k(3k+1)}{2}$或者$\frac{k(3k-1)}{2}$时才会有值

求出ai,大概是$O(sqrt(n))$级别的,然后就得到了$O(sqrt(n))$递推式子

(为啥是五边形数就不知道了。。。)

应用

Polya定理一些题,为了搞轮换会用到(一般就是dfs爆搜)

 

[学习笔记]整数划分数

原文:https://www.cnblogs.com/Miracevin/p/10392750.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!