admin管理员组文章数量:1122853
bellman
首先认真读题:(acwing853)
给定一个 n 个点 m 条边的有向图,图中可能存在重边和自环, 边权可能为负数。
请你求出从 1 号点到 n号点的最多经过 k 条边的最短距离,如果无法从 1 号点走到 n 号点,输出 impossible
。
注意:图中可能 存在负权回路 。
输入格式
第一行包含三个整数 n,m,k。
接下来 m 行,每行包含三个整数 x,y,z,表示存在一条从点 x 到点 y的有向边,边长为 z。
点的编号为 1∼n。
输出格式
输出一个整数,表示从 1 号点到 n 号点的最多经过 k 条边的最短距离。
如果不存在满足条件的路径,则输出 impossible
。
数据范围
1≤n,k≤500,
1≤m≤10000,
1≤x,y≤n,
任意边长的绝对值不超过 10000。
输入样例:
3 3 1
1 2 1
2 3 1
1 3 3
输出样例:
3
本题相较于最短路加了边数限制,必须在满足边数允许的条件下,才可以更新到该点的dist距离,同样我们可以遍历每一条边长
首先是对图片中代码的解释:
backup数组是对更新前dist数组的备份。防止发生串联的情况,例如1-2-3这是一条路径,边数限制k=1时,不备份的话我们可能先将dist【2】的数值更新,再用该数值将dist【3】给更新了。
为避免此类情况,我们可以先将dist数组备份。
对于最后范围false 还是true的条件判定,dist【n】大于0x3f3f3f3f /2;这里的除以2是因为,边的权值可能为负,也会将dist[n]给更新,这样dist[n]并不等于0x3f3f3f3f。
对于该数据范围 >0x3f3f3f3f / 2 就可以判断了;
以及要考虑到返回的数据值,如果dist【n】数据已被更新,返回d【n】,未被更新返回-1或者其他值来判断输出情况,要考虑最后d【n】被更新时恰好等于 判断未被更新的返回值的情况。所以这里函数用bool类型较好
本文标签: bellman
版权声明:本文标题:bellman 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1687434205a102125.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论