有一个N*N的网格,给定一个边的数组,依次从网格中去掉数组里的边,问去掉多少条边后网格中点(0,0)和点(N-1,N-1)不再连通。
这个问题可以转化成变种最短路径问题。初始化每条边的权值为MAX_INT,然后把数组中的边的权值改为这条边在数组中的顺序。这样求从点(0,0)到点(N-1,N-1)的距离就可以。
不过公式是
newNode.weight = min(edge(from node to newNode),node.weight);
如果点(N-1,N-1)的weight=INT_MAX,那么说明两点依然保持连通,在去掉所有数组中的边后。
否则,点(N-1,N-1)的weight就是最后的答案。
因为总共有2*N*N条边,最后的时间复杂度是O(N*NlgN)。