最短路-SPFA(Shortest Path Faster Algorithm)

SPFA求单源最短路

SPFA是使用了队列优化的单源最短路算法,与Dijkstra不同的是,它可以判断是否图中有负环。

它的实现与dijistra很相似,据说时间复杂度比dijkstra好

先看一下百度百科上的伪码:

ProcedureSPFA;
Begin
    initialize-single-source(G,s);
    initialize-queue(Q);
    enqueue(Q,s);
    while not empty(Q) do begin
        u:=dequeue(Q);
        for each v∈adj[u] do begin
            tmp:=d[v];
            relax(u,v);
            if(tmp<>d[v])and(not v in Q)then enqueue(Q,v);
        end;
    end;
End;

实现代码如下:

int SPFA(int u,int NV,int v)//参数依次:源<span style="font-family: Arial, Helvetica, sans-serif;">点</span><span style="font-family: Arial, Helvetica, sans-serif;">,图节点总数,终点</span>
{
    int Queue[N];
    int Count[N];//记录每个节点入队次数
    for(int i=1;i<=NV;i++)
    {
        dist[i]=MAX;
        vist[i]=0;
        Count[i]=0;
    }
    int head=0,rear=0;//队头队尾
    dist[u]=0;
    Queue[rear++]=u;
    Count[u]++;
    vist[u]=1;
    while(head<rear)
    {
        u=Queue[head++];
        vist[u]=0;//注意这里出队后把标记置回原来的0
        for(int i=1;i<=NV;i++)
        {
            if(dist[u]+Metrix[u][i]<dist[i])//这里是不是很熟悉
            {
                dist[i]=dist[u]+Metrix[u][i];
                if(vist[i]==0)
                {
                    Queue[rear++]=i;
                    vist[i]=1;
                    Count[i]++;
                    if(Count[i]>=NV)//这个if是判断负环的
                    {
                        return -1;
                    }
                }
            }
        }
    }
    return dist[v];
}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值