hdu5735】的更多相关文章

考虑DP,设$f[x]$表示最后一个是$x$时的最优解,则$f[x]=\max(f[y]+w[x]\ opt\ w[y])$,其中$y$是$x$的祖先. 注意到$w[i]<2^{16}$,那么将数字划分成前$8$位和后$8$位,额外维护一个数组$g[a][b]$表示某个$w[y]$的前$8$位为$a$时,后$8$位$opt\ b+f[y]$的最大值,那么维护$g$只需要枚举$b$,计算$f$只需要枚举$a$,单次复杂度都是$O(2^8)$. 对于树的情况只需要保存每次修改,然后在回溯的时候还原即…
很美妙的一题 官方题解 http://www.cnblogs.com/duoxiao/p/5777632.html 感觉有meet in middle的思想 #include<bits/stdc++.h> using namespace std; typedef long long ll; ; ]; unsigned ][],f[],tmp[][]; ],fa[],p[],v[],ans,len; ]; void add(int x,int y) { e[++len].po=y; e[len]…