hdu1874(Dijkstra&&spfa)

链接:点击打开链接

题意:求指定起点和指定终点的最短路

代码1:

#include <set>
#include <map>
#include <queue>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <iostream>
#include <algorithm>
using namespace std;
const int INF=0x3f3f3f3f;
struct node{
    int to,val;
};
vector<node> G[105];
int n,m,d[105],vis[105];
int dijkstra(int s,int t){
    int i,j,u,v,tt;
    memset(d,INF,sizeof(d));
    memset(vis,0,sizeof(vis));
    d[s]=0;
    while(1){
        tt=-1;
        for(i=0;i<n;i++)
        if(vis[i]==0&&(tt==-1||d[i]<d[tt]))
        tt=i;
        if(tt==-1)
        break;
        vis[tt]=1;
        for(i=0;i<G[tt].size();i++){
            u=G[tt][i].to;
            v=G[tt][i].val;
            d[u]=min(d[u],d[tt]+v);
        }
    }
    if(d[t]>=INF)
    return -1;
    return d[t];
}                                               //dijkstra模板
int main(){
    int i,j,u,v,val;
    while(scanf("%d%d",&n,&m)!=EOF){
        for(i=0;i<=n;i++)
        G[i].clear();
        for(i=0;i<m;i++){
            scanf("%d%d%d",&u,&v,&val);
            G[u].push_back((node){v,val});
            G[v].push_back((node){u,val});
        }
        scanf("%d%d",&u,&v);
        printf("%d\n",dijkstra(u,v));
    }
    return 0;
}

代码2:

#include <set>
#include <map>
#include <queue>
#include <vector>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <iostream>
#include <algorithm>
using namespace std;
const int INF=0x3f3f3f3f;
int n,m;
int d[105],vis[105];
struct node{
    int to,val;
};
vector<node> G[105];
int spfa(int S,int T){
    int i,j,u,v,w;
    queue<int> qu;
    memset(d,INF,sizeof(d));
    memset(vis,0,sizeof(vis));
    qu.push(S),d[S]=0,vis[S]=1;
    while(qu.size()){
        u=qu.front();
        qu.pop();
        vis[u]=0;
        for(i=0;i<G[u].size();i++){
            v=G[u][i].to;
            w=G[u][i].val;
            if(d[v]>d[u]+w){
                d[v]=d[u]+w;
                if(vis[v]==0){
                    vis[v]=1;
                    qu.push(v);
                }
            }
        }
    }
    if(d[T]>=INF)
    return -1;
    return d[T];
}                                               //spfa模板
int main(){
    int i,j,u,v,w;
    while(scanf("%d%d",&n,&m)!=EOF){
        for(i=0;i<=n;i++)
        G[i].clear();
        for(i=1;i<=m;i++){
            scanf("%d%d%d",&u,&v,&w);
            G[u].push_back((node){v,w});
            G[v].push_back((node){u,w});
        }
        scanf("%d%d",&u,&v);
        printf("%d\n",spfa(u,v));
    }
    return 0;
}

    原文作者:Dijkstra算法
    原文地址: https://blog.csdn.net/stay_accept/article/details/48528319
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞