PKU2486所谓树型DP

讲一下我想的算法吧...

刚开始就是搜 加了几个剪枝、记忆搜索,还是超时
最后想想用类似上次客户端-服务器的那个树型DP
/*

f[i][j][0]保存对于节点i向其子树走j步(可能有点重复)摘到的最多苹果数
f[i][j][1]保存对于节点i向其子树走j步 并且返回到i节点 摘到的最多苹果数

对于叶节点 f[i][0][0/1]=apNum[i];
对于其它节点f[i][j][0]=max{j-2*p-1步,其中p个子树返回,1个子树不需要返回,所得到最多苹果数,p不定};
   f[i][j][1]=max{j-2*p步,p个子树都返回,所得到的最多苹果数,p不定}
   这两步中间过程都需要DP 复杂度=j*子树个数(<n)

那么最终结果就是f[1][k][0]
整个大的DP时间复杂度<n*(k*n)<2*10^6

树型DP中套小DP

*/
实现起来好累哎。。。

转载于:https://www.cnblogs.com/SQL/archive/2007/10/08/917504.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值