题意
你有一个大小为n的背包,你有n种物品,第i种物品的大小为i,且有i个,求装满这个背包的方案数有多少
两种方案不同当且仅当存在至少一个数i满足第i种物品使用的数量不同
1<=n<=10^5,答案对23333333取模
分析
设lim=sqrt(n),我们把所有物品按照大于lim和不大于lim分成两部分。对于大于lim的部分,显然每种物品是一定用不完的,且在这部分所选物品数量一定不会超过lim。
那么我们可以对大于lim的部分进行dp,设g[i,j]表示我选了i种物品,和为j的方案数。转移为g[i,j]=g[i-1,j-lim-1]+g[i,j-i]。
再对不大于lim的部分进行dp,设f[i,j]表示前i种物品中选了若干种其和为j的方案数。转移的时候可以用类似单调队列优化多重背包的方法来优化。
最后统计答案即可,
时间复杂度