spfa模版

#include<bits/stdc++.h>

using namespace std;

int n,m;//点边
int beginn;

int u[500005],v[500005],w[500005];
int first[500005],nextt[500005]; 

long long dis[500005];
int book[500005];

int k2=0;

void clean()
{
    for(int i=1;i<=n;i++)
    {
        dis[i]=2147483647;
        if(i==beginn) dis[i]=0;
        
        first[i]=-1;
    }
    
    for(int i=1;i<=m;i++)
    {
        nextt[i]=-1;
    }
}

void make_edge(int _a,int _b,int _c)
{    
    k2++;
    u[k2]=_a;
    v[k2]=_b;
    w[k2]=_c;
    nextt[k2]=first[u[k2]];
    first[u[k2]]=k2;
}

deque<int> q; 

int main()
{
    cin>>n>>m>>beginn;
    
    clean();
    
    for(int i=1;i<=m;i++)
    {
        int a,b,c;
        cin>>a>>b>>c;
        make_edge(a,b,c);
    }
    
    book[beginn]=1;
    q.push_front(beginn);
    
    while(!q.empty())
    {
        int now_node=q.front();
        book[now_node]=0;
        q.pop_front();
        
        int k=first[u[now_node]];
        while(k!=-1)
        {
            if(dis[v[k]]>dis[u[k]]+w[k])
            {
                dis[v[k]]=dis[u[k]]+w[k];
                if(book[v[k]]==0)
                {
                    book[v[k]]=1;
                    if(!q.empty()&&dis[v[k]]<dis[q.front()])
                    {
                        q.push_front(v[k]);
                    }
                    else q.push_back(v[k]);
                }
            }
            k=nextt[k];
        }
    }
    
    for(int i=1;i<=n;i++)
    {
        if(i==beginn) cout<<"0 ";
        else cout<<dis[i]<<" ";
    }
    
    cout<<endl;
    return 0;
}

spfa未调过

原文地址:https://www.cnblogs.com/KyleDeng/p/10119535.html