Floyd求最短路
注意处理重边!
A的二维数组、自环路径大小置0、
if (A[i][k] != INF && A[k][j] != INF)、A[i][k] + A[k][j]而不是edges[i][k] + edges[k][j]这些注意点都和lc1334一样query函数–INF/2是什么意思?
INF / 2是为了避免整数加法时的溢出:因为在更新时,A[i][k]和A[k][j]若都是INF,则它们的和会大于等于INF,导致溢出;但Floyd算法中更新
A[i][j]的语句不需要INF/2,因为if (A[i][k] != INF && A[k][j] != INF)已经排除了A[i][k]和A[k][j]都是INF的情况
This post is licensed under CC BY 4.0 by the author.


