洛谷P3565 [POI2014]HOT-Hotels

f[i][j]表示离点i距离为j的点个数,g[i][j]表示点i子树外还需一个距离i为j的点对个数
ans=f[i][j]g[son][j+1]+g[i][j]f[son][j1] a n s = ∑ f [ i ] [ j ] ∗ g [ s o n ] [ j + 1 ] + ∑ g [ i ] [ j ] ∗ f [ s o n ] [ j − 1 ]
f[i][j]=f[son][j1],g[i][j]=g[son][j+1] f [ i ] [ j ] = ∑ f [ s o n ] [ j − 1 ] , g [ i ] [ j ] = ∑ g [ s o n ] [ j + 1 ]
然后发现f和g的转移可以通过移动数组的指针实现,对深度最大的儿子这样做一下,复杂度是O(n)的.
Code

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值