最短路径树(SPT)/CF1076D Edge Deletion

最短路径树,保证根节点到每个点都事其最短路。

最短路径树(SPT)/CF1076D Edge Deletion
的 spt 事
最短路径树(SPT)/CF1076D Edge Deletion
怎么求?
我谔谔
只需要在dij/spfa上动一点手脚。
\(dis_v>dis_u+edge(u,v)\) 时,把 \(v\) 的前驱标记为 \(u\)\(edge(u,v)\)
完结撒花!
有时我们需要使SPT边权和最小。
只需要加一个等于, \(dis_v\ge dis_u+edge(u,v)\)。为什么?我们要使满足 SPT 的同时 \(edge(u,v)\) 更小。
明显堆先取出来的 \(dis_u\) 更小。这时 \(dis_v\) 一定(即取等),所以 \(edge(u,v)\) 越大。后取出来的 \(edge(u,v)\) 就越小。
这道题,从根开始遍历,随便怎么取\(k\)个边就可以了。

最短路径树(SPT)/CF1076D Edge Deletion

上一篇:built-in commands


下一篇:03-XSS漏洞挖掘