用户工具

站点工具


2020-2021:teams:legal_string:lgwza:拆点

差别

这里会显示出您选择的修订版和当前版本之间的差别。

到此差别页面的链接

2020-2021:teams:legal_string:lgwza:拆点 [2020/08/29 23:05]
lgwza 创建
2020-2021:teams:legal_string:lgwza:拆点 [2020/08/29 23:07] (当前版本)
lgwza [分层图最短路]
行 21: 行 21:
 分层图最短路,如:有 $k$ 次零代价通过一条路径,求总的最小花费。对于这种题目,我们可以采用 DP 相关的思想,设 $\text{dis}_{i,​j}$ 表示当前从起点到 $i$ 号结点,使用了 $j$ 次免费通行权限后的最短路径。显然,$\text{dis}$ 数组可以这么转移: $$ 分层图最短路,如:有 $k$ 次零代价通过一条路径,求总的最小花费。对于这种题目,我们可以采用 DP 相关的思想,设 $\text{dis}_{i,​j}$ 表示当前从起点到 $i$ 号结点,使用了 $j$ 次免费通行权限后的最短路径。显然,$\text{dis}$ 数组可以这么转移: $$
 \text{dis}_{i,​j}=\min\{\min\{\text{dis}_{from,​j-1}\},​\min\{\text{dis}_{from,​j}+w\}\} \text{dis}_{i,​j}=\min\{\min\{\text{dis}_{from,​j-1}\},​\min\{\text{dis}_{from,​j}+w\}\}
-$$ 其中,$from$ 表示 $i$ 的父亲结点,$w$ 表示当前所走的边的边权。当 $j-1\ge k$ 时,$\text{dis}_{from,​j}=\infin$。+$$ 其中,$from$ 表示 $i$ 的父亲结点,$w$ 表示当前所走的边的边权。当 $j-1\ge k$ 时,$\text{dis}_{from,​j}=\infty$。
  
 事实上,这个 DP 就相当于把每个结点拆分成了 $k+1$ 个结点,每个新结点代表使用不同多次免费通行后到达的原图结点。换句话说,就是每个结点 $u_i$ 表示使用 $i$ 次免费通行权限后到达 $u$ 结点。 事实上,这个 DP 就相当于把每个结点拆分成了 $k+1$ 个结点,每个新结点代表使用不同多次免费通行后到达的原图结点。换句话说,就是每个结点 $u_i$ 表示使用 $i$ 次免费通行权限后到达 $u$ 结点。
2020-2021/teams/legal_string/lgwza/拆点.1598713558.txt.gz · 最后更改: 2020/08/29 23:05 由 lgwza