看动态规划看烦了,于是决定做一下我心心念念的图论。
这题简直就是水题,二分答案呗。然而!!!这题居然也有动规做法,真是气鼓鼓。
这个做法简直独一无二开创思维!!!!!
这文章转载了李煜东前辈的想法,但是他并没有发在网上,我也找不到链接了。特此鸣谢李煜东前辈。
用D(x, p)表示从1号节点到达基站x,途中已指定了p条电缆免费时,经过的路径上最贵的花费最小是多少(也就是选择一条从1到x的路径,使得路径上第p+1大的边权尽量小)。不难看出所求即为D(n, k)。若有一条边从x到y的无向边,长度为z,则应该用max(D[x, p], z)更新D[y, p]的最小值,用D[x, p]更新D[y, p + 1]的最小值。前者表示不修这条边,后者表示修这条边。
动态规划的无后效性告诉我们,动规对状态空间的遍历构成有向无环图,遍历顺序即为该有向无环图之拓扑序。点对应状态,边对应状态转移,转移的选取就是动规之决策。显然刚才的状态转移具有后效性(有环),在有后效性时,有一种解决方案就是利用迭代思想,借助spfa算法进行动规,直到所有状态收敛(无法疏松更新)。
从最短路角度理解,图中节点不仅限于一维,可以扩展至二维,用二元组(x, p)代表一个节点,从(x, p)到(y, p)有长度为z的边,从(x, p) 到 (y, p + 1)有长度为0的边。于是问题变为了从起点(1, 0)为源的广义单源最短路,包含nk个点,pk条边(但我个人感觉不是pk)。时间复杂度为O(tnp),t为常数,实测可以AC。