普及组模板——单源最短路径

Posted Yzyet

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了普及组模板——单源最短路径相关的知识,希望对你有一定的参考价值。

题目:【模板】单源最短路径(洛谷_3371)

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<queue>
#include<vector>
using namespace std;
inline int read(){
    int num=0,t=1;char c=getchar();
    while(c>\'9\'||c<\'0\'){if(c==\'-\')t=-1;c=getchar();}
    while(c>=\'0\'&&c<=\'9\'){num=(num<<1)+(num<<3)+c-\'0\';c=getchar();}
    return num*t;
}
const int N=10010,INF=0x7fffffff;
struct edge{int t,c;};
vector<edge> g[N];
typedef pair<int,int> P;
int d[N],n,m,s;
void dij(){
    priority_queue< P,vector<P>,greater<P> > q;
    for(int i=0;i<=n;i++)d[i]=INF;
    d[s]=0;q.push(P(0,s));
    while(!q.empty()){
        P p=q.top();q.pop();
        int x=p.second;
        if(d[x]<p.first)continue;
        for(int i=0;i<g[x].size();i++){
            edge e=g[x][i];
            if(d[e.t]>d[x]+e.c){
                d[e.t]=d[x]+e.c;
                q.push(P(d[e.t],e.t));
            }
        }
    }
}
int main()
{
    n=read();m=read();s=read();
    for(int i=1;i<=m;i++){
        int a=read(),b=read(),c=read();
        g[a].push_back((edge){b,c});
    }
    dij();
    for(int i=1;i<=n;i++)printf("%d ",d[i]);
    return 0;
}

本文由Yzyet编写,网址为www.cnblogs.com/Yzyet。非Yzyet同意,禁止转载,侵权者必究。

以上是关于普及组模板——单源最短路径的主要内容,如果未能解决你的问题,请参考以下文章

单源最短路径模板(弱化版)

P3371 模板单源最短路径(弱化版)

P4779 模板单源最短路径(标准版)

[模板]单源最短路径(Dijkstra)

模板:单源最短路径

P4779 模板单源最短路径(标准版)单源最短路Dijkstra