• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 21,  comments - 9,  trackbacks - 0
            此題大意為求從頂點(diǎn)1到頂點(diǎn)n的最短路徑。
            所以采用最短路徑的算法。
            想省事的話,可以使用弗洛伊德,但是n的值為10^5,這樣肯定超時(shí)。
            所以本題采用SPFA算法。見下面代碼
            #include<stdio.h>
            #include<malloc.h>
            #include<queue>
            #include<string.h>
            using namespace std;
            typedef struct node
            {
                int id;
                int distance;
                struct node *next;
            }Node,*LNode;
            int n,m;
            LNode array[100010];//鄰接鏈表
            int in_queue[100010];//記錄一個(gè)點(diǎn)是否在隊(duì)列中
            int between_distance[100010];//記錄起始點(diǎn)到兩個(gè)點(diǎn)之間的距離
            queue<int> q;//建立一個(gè)隊(duì)列

            void init_array()
            {
                for(int i = 0;i <= n;++i)
                {
                    array[i] = (LNode)malloc(sizeof(Node));
                    array[i]->id = i;
                    array[i]->distance = 0;
                    array[i]->next = NULL;
                }
            }

            void insert_node(LNode header,LNode &insert_node)
            {
                while(header->next != NULL)
                    header = header->next;
                insert_node->next = header->next;
                header->next = insert_node;
            }

            //任何兩點(diǎn)之間的距離設(shè)置為-1,表示正無(wú)窮
            void init_distance()
            {
                for(int i = 0;i <= n;++i)
                {
                    between_distance[i] = -1;
                }
                //第一個(gè)結(jié)點(diǎn)到自身為0
                between_distance[1] = 0;
            }

            //松弛
            void relax(int index)
            {
                if(between_distance[index] == -1)
                    return ;
                LNode header = array[index]->next;
                while(header != NULL)
                {
                    if(between_distance[header->id] > between_distance[index] + header->distance || between_distance[header->id] == -1)
                    {
                        between_distance[header->id] = between_distance[index] + header->distance;
                        if(!in_queue[header->id])
                        {
                            q.push(header->id);
                            in_queue[header->id] = 1;
                        }
                    }
                    header = header->next;
                }
            }

            void SPFA()
            {
                //第一個(gè)點(diǎn)入隊(duì)列
                q.push(1);
                in_queue[1] = 1;
                int index = 0;
                while(!q.empty())
                {
                    index = q.front();
                    q.pop();
                    in_queue[index] = 0;
                    relax(index);
                }
            }

            int main()
            {
                int x,y,distance;
                scanf("%d%d",&n,&m);
                init_array();
                for(int i = 0;i < m;++i)
                {
                    scanf("%d%d%d",&x,&y,&distance);
                    LNode node = (LNode)malloc(sizeof(Node));
                    node->id = y;
                    node->distance = distance;
                    insert_node(array[x],node);
                    node = (LNode)malloc(sizeof(Node));
                    node->id = x;
                    node->distance = distance;
                    insert_node(array[y],node);
                }
                init_distance();
                memset(in_queue,0,sizeof(in_queue));
                SPFA();
                if(between_distance[n] == -1)
                {
                    printf("-1\n");
                }
                else
                    printf("%d\n",between_distance[n]);
                return 0;
            }
            posted on 2012-04-06 19:59 崔佳星 閱讀(379) 評(píng)論(0)  編輯 收藏 引用 所屬分類: xoj
            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            狠狠狠色丁香婷婷综合久久俺| 偷窥少妇久久久久久久久| 久久精品无码一区二区WWW| 亚洲国产成人久久精品99 | 欧美久久久久久| 久久久久亚洲AV成人网人人网站| 奇米影视7777久久精品人人爽| 蜜桃麻豆WWW久久囤产精品| 久久午夜无码鲁丝片| 狠色狠色狠狠色综合久久| 久久久精品视频免费观看| 久久国产精品无| 久久久久久综合一区中文字幕 | 精品久久久久久无码国产| 伊人久久精品影院| 97热久久免费频精品99| 欧美久久亚洲精品| 久久精品亚洲日本波多野结衣 | 久久精品成人| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 久久人与动人物a级毛片| 97久久超碰国产精品旧版 | 狠狠色婷婷久久综合频道日韩| 国产精品一久久香蕉国产线看| 久久久久亚洲精品中文字幕| 欧美牲交A欧牲交aⅴ久久| 久久久免费观成人影院| 久久精品国产亚洲av水果派 | 老色鬼久久亚洲AV综合| 一本久久精品一区二区| 国产精品嫩草影院久久| 久久99国产精品尤物| 伊人久久大香线蕉亚洲五月天| 久久男人AV资源网站| 久久99国产精品久久99| 91精品国产高清久久久久久io| 97视频久久久| 久久久久久国产a免费观看黄色大片 | 国产精品美女久久久网AV| 伊人色综合久久天天| 99久久免费国产精品|