前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >图论--最短路--dijkstra(含路径输出)模板

图论--最短路--dijkstra(含路径输出)模板

作者头像
风骨散人Chiam
发布2020-10-28 14:40:26
6670
发布2020-10-28 14:40:26
举报
文章被收录于专栏:CSDN旧文
代码语言:javascript
复制
#include<iostream>
#include<stack>
#include<queue>
#include<cstring>
#include<cstdio>
using namespace std;
typedef long long ll;
typedef pair<int,int> PII;
struct Node
{
    int var,next,val;
} edge[100000005];
int head[100005],tot,dis[100005],N,M;
int pre[100005]; //松弛数组
bool vis[100005]; //唯一定理
priority_queue<PII> Q; //大根堆优化
void add(int a, int b, int c)
{
    edge[++tot].var = b;
    edge[tot].val = c;
    edge[tot].next = head[a];
    head[a] = tot;
}
void init()//多组输入调用
{
    tot=0;
    memset(head,0,sizeof(head));
}
void dijkstra(int s)
{
    memset(dis,0x3f,sizeof(dis));
    memset(vis,0,sizeof(vis));
    memset(pre,-1,sizeof(pre));
    while(Q.size()) Q.pop();
    dis[s] = 0;
    Q.push(make_pair(0,s));
    while(!Q.empty())
    {
        int x=Q.top().second;
        Q.pop();
        if(vis[x])continue;
        vis[x]=1;
        for(int i=head[x]; i; i=edge[i].next)
        {
            int y=edge[i].var;
            if(dis[x]+edge[i].val<dis[y]) //图论三角不等式
            {
                dis[y]=dis[x]+edge[i].val;
                if(!vis[y])
                Q.push(make_pair(-dis[y],y));
                pre[y]=x;
            }
        }

    }
}
int main()
{
    int S,E;
    init();
   cin>>N>>M>>S>>E;
    while(M--)
    {
        int x,y,z;
        cin>>x>>y>>z;
        add(x+1,y+1,z);
    }
    dijkstra(S+1);
    if(dis[E+1]>0x3f000000)
    {
        cout<<"no answer"<<endl;
        return 0;
    }
    cout<<dis[E+1]<<endl;
    stack<int> ans;
    for(int i=E+1;i!=-1;i=pre[i])
    {
        ans.push(i-1);
        //cout<<i-1<<endl;
    }
    while(ans.size())
    {
        cout<<'v';
        cout<<ans.top()<<" ";
        ans.pop();
    }
    puts("");
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/12/03 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档