Chinaunix首页 | 论坛 | 博客
  • 博客访问: 38519
  • 博文数量: 64
  • 博客积分: 2640
  • 博客等级: 少校
  • 技术积分: 670
  • 用 户 组: 普通用户
  • 注册时间: 2010-01-26 13:15
文章分类
文章存档

2010年(64)

我的朋友
最近访客

分类: C/C++

2010-01-26 13:59:40

2009-03-30 17:00 

#include<iostream>
#include<fstream>
using namespace std;
const int MAX = 100;
const int INFI = 100000;
#define WHITE 0
#define GRAY -1
#define BLACK 1
struct{
      int n;
      int adjvex[MAX];
      int weight[MAX];
}Edge[MAX];
int List[MAX],k;
int color[MAX];
int D[MAX],father[MAX];
void DFS(int cur){
     int i,next;
    
     color[cur] = GRAY;
     for(i=0;i<Edge[cur].n;i++){
         next = Edge[cur].adjvex[i];
        
         if(color[next]==WHITE) DFS(next);
         else if(color[next]==GRAY){//有回边出现意味着有回路

              cout<<"Circuit exists!"<<endl;
              system("pause");
              exit(0);
         }
     }
    
     color[cur] = BLACK;
     List[--k] = cur;//按节点完成的顺序入列

}
void TopologicalSort(int n){
     int i,j;
    
     k = n;
     memset(color,0,sizeof(color) );
     DFS(1);
}
void DAG_SP(int s,int n);
int main(void){
    int n,e,s,a,b,v;
    int i,j;
    ifstream in("data.in");
    ofstream out("data.out");
   
    in>>n>>e>>s;
    for(i=1;i<=n;i++)
        Edge[i].n = 0;
   
    for(i=0;i<e;i++){
        in>>a>>b>>v;
        Edge[a].adjvex[ Edge[a].n ] = b;
        Edge[a].weight[ Edge[a].n++ ] = v;
    }
   
    DAG_SP(s,n);
   
    for(i=1;i<=n;i++)
        out<<i<<" "<<D[i]<<" "<<father[i]<<endl;
   
    system("pause");
    return 0;
}
void DAG_SP(int s,int n){
     int i,j,u,v,w;
    
     TopologicalSort(n);
    
     for(i=1;i<=n;i++){
         D[i] = INFI;
         father[i] = 0;
     }
     D[s] = 0;
    
     for(i=0;i<n;i++){
         u = List[i];
         for(j=0;j<Edge[u].n;j++){
             v = Edge[u].adjvex[j];
             w = Edge[u].weight[j];
             if(D[v]>D[u]+w){
                D[v] = D[u] + w;
                father[v] = u;
             }
         }
     }
}


阅读(364) | 评论(0) | 转发(0) |
0

上一篇:有向图的传递闭包

下一篇:BellmanFord

给主人留下些什么吧!~~