Dijksrta&&Spfa

Dijkstra算法

void Dijkstra(ints)

{

      memset(mark,0,sizeofmark);

      mark[s]=1;

      for(inti=1;i<=n;i++)

           dis[i]=e[s][i];

      dis[s]=0;

 

      intt=n;

      while(t--)

      {

           intmin=Inf;

           intk;

           for(inti=1;i<=n;i++)

                 if(!mark[i]&&dis[i]<min)

                 {

                      min=dis[i];

                      k=i;

                 }

           if(min==Inf)

                 continue;

           mark[k]=1;

           for(inti=1;i<=n;i++)

                 if(!mark[i]&&dis[k]+e[k][i]<dis[i])

                      dis[i]=dis[k]+e[k][i];

      }

#include<iostream>

#define N1002

#define M20002

struct Edge

{

      intv,next,w;

}edge[M];

int head[N],dis[N],mark[N],cnt[N];

int n,m,s;

 

bool Spfa()

{

      memset(mark,0,sizeofmark);

      memset(cnt,0,sizeofcnt);

      for(inti=0;i<=n;i++) dis[i]=Inf;

      dis[s]=0;mark[s]=1;

      Q<int> q;

      q.push(s);

      while(!q.empty())

      {

           inte=q.front(); q.pop();

           mark[e]=0;

           for(inti=head[e];i!=-1;i=edge[i].next)

           {

                 intv=edge[i].v;

                 if(dis[v]>dis[e]+edge[i].w)

                 {

                      dis[v]=dis[e]+edge[i].w;

 

                      if(!mark[v])

                      {

                            q.push(v);

                            mark[v]=1;

 

                            if(++cnt[v]>=n)

                                  returnfalse;

                      }

                 }

           }

      }

      returntrue;

}

 

int main()

{

      while(scanf("%d%d%d",&n,&m,&s)!=EOF)

      {

           memset(head,-1,sizeofhead);

           for(inti=1;i<=m;i++)

           {

                 intu,v,w;

                 scanf("%d%d%d",&u,&v,&w);

                 edge[i].v=v;

                 edge[i].w=w;

                 edge[i].next=head[u];

                 head[u]=i;

           }

           Spfa();

      }

      return0;

}

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值