51nod 1597 有限背包计数问题 dp

该博客探讨了一个有限背包问题,其中你需要使用不同数量的n种物品(大小从1到n,数量相同)来填满一个容量为n的背包。问题的重点在于找到不同装满背包的方案数,对特定模数取余。博主通过将物品分为大于和小于等于平方根(n)两部分,并分别应用动态规划(DP)策略进行解决,时间复杂度为O(n*sqrt(n))。
摘要由CSDN通过智能技术生成

题意

你有一个大小为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的方案数。转移的时候可以用类似单调队列优化多重背包的方法来优化。
最后统计答案即可,
时间复杂度

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值