codility上的一道题

来源:互联网 发布:网络英语教学平台排名 编辑:程序博客网 时间:2024/04/29 09:04

有一个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)。       

原创粉丝点击