ZOJ——2760——HOW many shortest path

  题目的意思是要求都多少边不重合的最短路。可以先用一个二重循环算出哪些边在可在最短路中,然后给他们赋值容量1,然后再从求个最大流就好了。下面给出计算哪些边在最短路径中的代码。
void  floyd()  {
   
   
for(int k = 0; k < n; k++
      
for(int i = 0; i < n; i++
         
if(d[i][k] != INF ) 
            
for(int j = 0; j < n; j++{
               
if(d[k][j] != INF) {
                   
if(d[i][j] > d[k][j] + d[i][k]) {
                      d[i][j] 
= d[k][j] + d[i][k];
                   }
 
               }

            }

   
   
for(int i = 0; i < n; i++)
      
if(d[s][i] != INF)
         
for(int j = 0; j < n; j++{
           
if(d[j][t] != INF)
            
if(mat[i][j] != -1 ){
               
if(d[s][t] == d[s][i] + mat[i][j] + d[j][t]) {
                 c[i][j] 
= 1;
               }

            }

         }
 
    
}
 

你可能感兴趣的:(ZOJ——2760——HOW many shortest path)