现在的位置: 首页 > 综合 > 正文

最短路算法的整理

2013年12月04日 ⁄ 综合 ⁄ 共 328字 ⁄ 字号 评论关闭

Floyd-Warshall算法

        for (int k=1;k<=n;k++)
        {
            for (int i=1;i<=n;i++)
            {
                for (int j=1;j<=n;j++)
                {
                    if (a[i][k]+a[k][j]<a[i][j])
                    {
                        a[i][j]=a[i][k]+a[k][j];
                    }
                }
            }
        }

Bellman-Ford算法

        for (int loop=1;loop<=n;loop++)
        {
            flag=true;
            for (int i=1;i<=n;i++)
            {
                for (int j=1;j<=n;j++)
                {
                    if (a[i][j]!=0)
                    {
                        if (dist[j]>dist[i]+a[i][j])
                        {
                            dist[j]=dist[i]+a[i][j];
                            flag=false;
                        }
                    }
                }
            }
            if (flag)break;
        }

抱歉!评论已关闭.