[JZOJ4390] 图计数

本文探讨了求解正整数NN的自然数拆分方案数的问题。通过将问题转化为完全背包问题,并采用分块技术,提出了两种DP思路,最终实现了时间复杂度为O(N√⋅N)的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Description

问正整数N的自然数拆分方案数。

Constraint

N2×105

Analysis

题目相当于物品是1N,体积是N的完全背包方案数。
我们考虑对物品分块。

  1. vi<N,使用正常的DP思路,转移是fi,j=fi1,j+fi,jvi
    时间复杂度是O(NN)

    • viN,因为被选择的物品不会超过N个,
      考虑另一种DP思路,两种转移,一种是加入一个大小为N的物品,
      另一种是把所有物品大小全部加1,所以转移是gi,j=gi1,jN+gi,ji
      时间复杂度是O(NN)

    • 总时间复杂度:O(NN)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值