成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識(shí)庫 > 算法系列15天速成——第十五天 圖【下】(大結(jié)局)

算法系列15天速成——第十五天 圖【下】(大結(jié)局)

熱門標(biāo)簽:地圖標(biāo)注和圖片標(biāo)注 醫(yī)院地圖標(biāo)注 忻州外呼系統(tǒng)接口對(duì)接 滄州智能外呼系統(tǒng)收費(fèi) 嘟聲的電銷機(jī)器人 洛陽便宜外呼系統(tǒng)廠家 語音平臺(tái)系統(tǒng) 電銷機(jī)器人怎么收費(fèi) 湖北穩(wěn)定外呼系統(tǒng)
今天是大結(jié)局,說下“圖”的最后一點(diǎn)東西,“最小生成樹“和”最短路徑“。

一: 最小生成樹

1. 概念

    首先看如下圖,不知道大家能總結(jié)點(diǎn)什么。

    對(duì)于一個(gè)連通圖G,如果其全部頂點(diǎn)和一部分邊構(gòu)成一個(gè)子圖G1,當(dāng)G1滿足:

       ① 剛好將圖中所有頂點(diǎn)連通。②頂點(diǎn)不存在回路。則稱G1就是G的“生成樹”。

           其實(shí)一句話總結(jié)就是:生成樹是將原圖的全部頂點(diǎn)以最小的邊連通的子圖,這不,如下的連通圖可以得到下面的兩個(gè)生成樹。

       ② 對(duì)于一個(gè)帶權(quán)的連通圖,當(dāng)生成的樹不同,各邊上的權(quán)值總和也不同,如果某個(gè)生成樹的權(quán)值最小,則它就是“最小生成樹”。

     

2. 場(chǎng)景

      實(shí)際應(yīng)用中“最小生成樹”還是蠻有實(shí)際價(jià)值的,教科書上都有這么一句話,若用圖來表示一個(gè)交通系統(tǒng),每一個(gè)頂點(diǎn)代表一個(gè)城市,

  邊代表兩個(gè)城市之間的距離,當(dāng)有n個(gè)城市時(shí),可能會(huì)有n(n-1)/2條邊,那么怎么選擇(n-1)條邊來使城市之間的總距離最小,其實(shí)它

  的抽象模型就是求“最小生成樹”的問題。

 

3. prim算法

    當(dāng)然如何求“最小生成樹”問題,前人都已經(jīng)給我們總結(jié)好了,我們只要照葫蘆畫瓢就是了,

    第一步:我們建立集合“V,U",將圖中的所有頂點(diǎn)全部灌到V集合中,U集合初始為空。

    第二步: 我們將V1放入U(xiǎn)集合中并將V1頂點(diǎn)標(biāo)記為已訪問。此時(shí):U(V1)。

    第三步: 我們尋找V1的鄰接點(diǎn)(V2,V3,V5),權(quán)值中發(fā)現(xiàn)(V1,V2)之間的權(quán)值最小,此時(shí)我們將V2放入U(xiǎn)集合中并標(biāo)記V2為已訪問,

                此時(shí)為U(V1,V2)。

    第四步: 我們找U集合中的V1和V2的鄰接邊,一陣痙攣后,發(fā)現(xiàn)(V1,V5)的權(quán)值最小,此時(shí)將V5加入到U集合并標(biāo)記為已訪問,此時(shí)

                 U的集合元素為(V1,V2,V5)。

    第五步:此時(shí)我們以(V1,V2,V5)為基準(zhǔn)向四周尋找最小權(quán)值的鄰接邊,發(fā)現(xiàn)(V5,V4)的權(quán)值最小,此時(shí)將V4加入到U集合并標(biāo)記

                 為已訪問,此時(shí)U的集合元素為(V1,V2,V5,V4)。

    第六步: 跟第五步形式一樣,找到了(V1,V3)的權(quán)值最小,將V3加入到U集合中并標(biāo)記為已訪問,最終U的元素為(V1,V2,V5,V4,V3),

最終發(fā)現(xiàn)頂點(diǎn)全部被訪問,最小生成樹就此誕生。

復(fù)制代碼 代碼如下:

#region prim算法獲取最小生成樹
        /// summary>
/// prim算法獲取最小生成樹
/// /summary>
/// param name="graph">/param>
        public void Prim(MatrixGraph graph, out int sum)
        {
            //已訪問過的標(biāo)志
            int used = 0;

            //非鄰接頂點(diǎn)標(biāo)志
            int noadj = -1;

            //定義一個(gè)輸出總權(quán)值的變量
            sum = 0;

            //臨時(shí)數(shù)組,用于保存鄰接點(diǎn)的權(quán)值
            int[] weight = new int[graph.vertexNum];

            //臨時(shí)數(shù)組,用于保存頂點(diǎn)信息
            int[] tempvertex = new int[graph.vertexNum];

            //取出鄰接矩陣的第一行數(shù)據(jù),也就是取出第一個(gè)頂點(diǎn)并將權(quán)和邊信息保存于臨時(shí)數(shù)據(jù)中
            for (int i = 1; i graph.vertexNum; i++)
            {
                //保存于鄰接點(diǎn)之間的權(quán)值
                weight[i] = graph.edges[0, i];

                //等于0則說明V1與該鄰接點(diǎn)沒有邊
                if (weight[i] == short.MaxValue)
                    tempvertex[i] = noadj;
                else
                    tempvertex[i] = int.Parse(graph.vertex[0]);
            }

            //從集合V中取出V1節(jié)點(diǎn),只需要將此節(jié)點(diǎn)設(shè)置為已訪問過,weight為0集合
            var index = tempvertex[0] = used;
            var min = weight[0] = short.MaxValue;

            //在V的鄰接點(diǎn)中找權(quán)值最小的節(jié)點(diǎn)
            for (int i = 1; i graph.vertexNum; i++)
            {
                index = i;
                min = short.MaxValue;

                for (int j = 1; j graph.vertexNum; j++)
                {
                    //用于找出當(dāng)前節(jié)點(diǎn)的鄰接點(diǎn)中權(quán)值最小的未訪問點(diǎn)
                    if (weight[j] min tempvertex[j] != 0)
                    {
                        min = weight[j];
                        index = j;
                    }
                }
                //累加權(quán)值
                sum += min;

                Console.Write("({0},{1})  ", tempvertex[index], graph.vertex[index]);

                //將取得的最小節(jié)點(diǎn)標(biāo)識(shí)為已訪問
                weight[index] = short.MaxValue;
                tempvertex[index] = 0;

                //從最新的節(jié)點(diǎn)出發(fā),將此節(jié)點(diǎn)的weight比較賦值
                for (int j = 0; j graph.vertexNum; j++)
                {
                    //已當(dāng)前節(jié)點(diǎn)為出發(fā)點(diǎn),重新選擇最小邊
                    if (graph.edges[index, j] weight[j] tempvertex[j] != used)
                    {
                        weight[j] = graph.edges[index, j];

                        //這里做的目的將較短的邊覆蓋點(diǎn)上一個(gè)節(jié)點(diǎn)的鄰接點(diǎn)中的較長(zhǎng)的邊
                        tempvertex[j] = int.Parse(graph.vertex[index]);
                    }
                }
            }
        }
        #endregion

二: 最短路徑

1.   概念

        求最短路徑問題其實(shí)也是非常有實(shí)用價(jià)值的,映射到交通系統(tǒng)圖中,就是求兩個(gè)城市間的最短路徑問題,還是看這張圖,我們可以很容易的看出比如

     V1到圖中各頂點(diǎn)的最短路徑。

      ① V1  ->  V2              直達(dá),     權(quán)為2。

      ② V1  ->  V3              直達(dá)        權(quán)為3。

      ③ V1->V5->V4           中轉(zhuǎn)       權(quán)為3+2=5。

      ④ V1  ->  V5               直達(dá)      權(quán)為3。

  、

2.  Dijkstra算法

      我們的學(xué)習(xí)需要站在巨人的肩膀上,那么對(duì)于現(xiàn)實(shí)中非常復(fù)雜的問題,我們肯定不能用肉眼看出來,而是根據(jù)一定的算法推導(dǎo)出來的。

  Dijkstra思想遵循 “走一步,看一步”的原則。

     第一步: 我們需要一個(gè)集合U,然后將V1放入U(xiǎn)集合中,既然走了一步,我們就要看一步,就是比較一下V1的鄰接點(diǎn)(V2,V3,V5),

                 發(fā)現(xiàn)(V1,V2)的權(quán)值最小,此時(shí)我們將V2放入U(xiǎn)集合中,表示我們已經(jīng)找到了V1到V2的最短路徑。

     第二步:然后將V2做中間點(diǎn),繼續(xù)向前尋找權(quán)值最小的鄰接點(diǎn),發(fā)現(xiàn)只有V4可以連通,此時(shí)修改V4的權(quán)值為(V1,V2)+(V2,V4)=6。

                此時(shí)我們就要看一步,發(fā)現(xiàn)V1到(V3,V4,V5)中權(quán)值最小的是(V1,V5),此時(shí)將V5放入U(xiǎn)集合中,表示我們已經(jīng)找到了

                V1到V5的最短路徑。

     第三步:然后將V5做中間點(diǎn),繼續(xù)向前尋找權(quán)值最小的鄰接點(diǎn),發(fā)現(xiàn)能連通的有V3,V4,當(dāng)我們正想修該V3的權(quán)值時(shí)發(fā)現(xiàn)(V1,V3)的權(quán)值

                小于(V1->V5->V3),此時(shí)我們就不修改,將V3放入U(xiǎn)集合中,最后我們找到了V1到V3的最短路徑。

     第四步:因?yàn)閂5還沒有走完,所以繼續(xù)用V5做中間點(diǎn),此時(shí)只能連通(V5,V4),當(dāng)要修改權(quán)值的時(shí)候,發(fā)現(xiàn)原來的V4權(quán)值為(V1,V2)+(V2,V4),而

                現(xiàn)在的權(quán)值為5,小于先前的6,此時(shí)更改原先的權(quán)值變?yōu)?,將V4放入集合中,最后我們找到了V1到V4的最短路徑。

復(fù)制代碼 代碼如下:

#region dijkstra求出最短路徑
        /// summary>
/// dijkstra求出最短路徑
/// /summary>
/// param name="g">/param>
        public void Dijkstra(MatrixGraph g)
        {
            int[] weight = new int[g.vertexNum];

            int[] path = new int[g.vertexNum];

            int[] tempvertex = new int[g.vertexNum];

            Console.WriteLine("\n請(qǐng)輸入源點(diǎn)的編號(hào):");

            //讓用戶輸入要遍歷的起始點(diǎn)
            int vertex = int.Parse(Console.ReadLine()) - 1;

            for (int i = 0; i g.vertexNum; i++)
            {
                //初始賦權(quán)值
                weight[i] = g.edges[vertex, i];

                if (weight[i] short.MaxValue weight[i] > 0)
                    path[i] = vertex;

                tempvertex[i] = 0;
            }

            tempvertex[vertex] = 1;
            weight[vertex] = 0;

            for (int i = 0; i g.vertexNum; i++)
            {
                int min = short.MaxValue;

                int index = vertex;

                for (int j = 0; j g.vertexNum; j++)
                {
                    //頂點(diǎn)的權(quán)值中找出最小的
                    if (tempvertex[j] == 0 weight[j] min)
                    {
                        min = weight[j];
                        index = j;
                    }
                }

                tempvertex[index] = 1;

                //以當(dāng)前的index作為中間點(diǎn),找出最小的權(quán)值
                for (int j = 0; j g.vertexNum; j++)
                {
                    if (tempvertex[j] == 0 weight[index] + g.edges[index, j] weight[j])
                    {
                        weight[j] = weight[index] + g.edges[index, j];
                        path[j] = index;
                    }
                }
            }

            Console.WriteLine("\n頂點(diǎn){0}到各頂點(diǎn)的最短路徑為:(終點(diǎn) 源點(diǎn)) " + g.vertex[vertex]);

            //最后輸出
            for (int i = 0; i g.vertexNum; i++)
            {
                if (tempvertex[i] == 1)
                {
                    var index = i;

                    while (index != vertex)
                    {
                        var j = index;
                        Console.Write("{0} ", g.vertex[index]);
                        index = path[index];
                    }
                    Console.WriteLine("{0}\n", g.vertex[index]);
                }
                else
                {
                    Console.WriteLine("{0} - {1}: 無路徑\n", g.vertex[i], g.vertex[vertex]);
                }
            }
        }
        #endregion

最后上一下總的運(yùn)行代碼

復(fù)制代碼 代碼如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace MatrixGraph
{
    public class Program
    {
        static void Main(string[] args)
        {
            MatrixGraphManager manager = new MatrixGraphManager();

            //創(chuàng)建圖
            MatrixGraph graph = manager.CreateMatrixGraph();

            manager.OutMatrix(graph);

            int sum = 0;

            manager.Prim(graph, out sum);

            Console.WriteLine("\n最小生成樹的權(quán)值為:" + sum);

            manager.Dijkstra(graph);

            //Console.Write("廣度遞歸:\t");

//manager.BFSTraverse(graph);

//Console.Write("\n深度遞歸:\t");

//manager.DFSTraverse(graph);

            Console.ReadLine();

        }
    }

    #region 鄰接矩陣的結(jié)構(gòu)圖
    /// summary>
/// 鄰接矩陣的結(jié)構(gòu)圖
/// /summary>
    public class MatrixGraph
    {
        //保存頂點(diǎn)信息
        public string[] vertex;

        //保存邊信息
        public int[,] edges;

        //深搜和廣搜的遍歷標(biāo)志
        public bool[] isTrav;

        //頂點(diǎn)數(shù)量
        public int vertexNum;

        //邊數(shù)量
        public int edgeNum;

        //圖類型
        public int graphType;

        /// summary>
/// 存儲(chǔ)容量的初始化
/// /summary>
/// param name="vertexNum">/param>
/// param name="edgeNum">/param>
/// param name="graphType">/param>
        public MatrixGraph(int vertexNum, int edgeNum, int graphType)
        {
            this.vertexNum = vertexNum;
            this.edgeNum = edgeNum;
            this.graphType = graphType;

            vertex = new string[vertexNum];
            edges = new int[vertexNum, vertexNum];
            isTrav = new bool[vertexNum];
        }

    }
    #endregion

    /// summary>
/// 圖的操作類
/// /summary>
    public class MatrixGraphManager
    {
        #region 圖的創(chuàng)建
        /// summary>
/// 圖的創(chuàng)建
/// /summary>
/// param name="g">/param>
        public MatrixGraph CreateMatrixGraph()
        {
            Console.WriteLine("請(qǐng)輸入創(chuàng)建圖的頂點(diǎn)個(gè)數(shù),邊個(gè)數(shù),是否為無向圖(0,1來表示),已逗號(hào)隔開。");

            var initData = Console.ReadLine().Split(',').Select(i => int.Parse(i)).ToList();

            MatrixGraph graph = new MatrixGraph(initData[0], initData[1], initData[2]);

            //我們默認(rèn)“正無窮大為沒有邊”
            for (int i = 0; i graph.vertexNum; i++)
            {
                for (int j = 0; j graph.vertexNum; j++)
                {
                    graph.edges[i, j] = short.MaxValue;
                }
            }

            Console.WriteLine("請(qǐng)輸入各頂點(diǎn)信息:");

            for (int i = 0; i graph.vertexNum; i++)
            {
                Console.Write("\n第" + (i + 1) + "個(gè)頂點(diǎn)為:");

                var single = Console.ReadLine();

                //頂點(diǎn)信息加入集合中
                graph.vertex[i] = single;
            }

            Console.WriteLine("\n請(qǐng)輸入構(gòu)成兩個(gè)頂點(diǎn)的邊和權(quán)值,以逗號(hào)隔開。\n");

            for (int i = 0; i graph.edgeNum; i++)
            {
                Console.Write("第" + (i + 1) + "條邊:\t");

                initData = Console.ReadLine().Split(',').Select(j => int.Parse(j)).ToList();

                int start = initData[0];
                int end = initData[1];
                int weight = initData[2];

                //給矩陣指定坐標(biāo)位置賦值
                graph.edges[start - 1, end - 1] = weight;

                //如果是無向圖,則數(shù)據(jù)呈“二,四”象限對(duì)稱
                if (graph.graphType == 1)
                {
                    graph.edges[end - 1, start - 1] = weight;
                }
            }

            return graph;
        }
        #endregion

        #region 輸出矩陣數(shù)據(jù)
        /// summary>
/// 輸出矩陣數(shù)據(jù)
/// /summary>
/// param name="graph">/param>
        public void OutMatrix(MatrixGraph graph)
        {
            for (int i = 0; i graph.vertexNum; i++)
            {
                for (int j = 0; j graph.vertexNum; j++)
                {
                    if (graph.edges[i, j] == short.MaxValue)
                        Console.Write("∽\t");
                    else
                        Console.Write(graph.edges[i, j] + "\t");
                }
                //換行
                Console.WriteLine();
            }
        }
        #endregion

        #region 廣度優(yōu)先
        /// summary>
/// 廣度優(yōu)先
/// /summary>
/// param name="graph">/param>
        public void BFSTraverse(MatrixGraph graph)
        {
            //訪問標(biāo)記默認(rèn)初始化
            for (int i = 0; i graph.vertexNum; i++)
            {
                graph.isTrav[i] = false;
            }

            //遍歷每個(gè)頂點(diǎn)
            for (int i = 0; i graph.vertexNum; i++)
            {
                //廣度遍歷未訪問過的頂點(diǎn)
                if (!graph.isTrav[i])
                {
                    BFSM(ref graph, i);
                }
            }
        }

        /// summary>
/// 廣度遍歷具體算法
/// /summary>
/// param name="graph">/param>
        public void BFSM(ref MatrixGraph graph, int vertex)
        {
            //這里就用系統(tǒng)的隊(duì)列
            Queueint> queue = new Queueint>();

            //先把頂點(diǎn)入隊(duì)
            queue.Enqueue(vertex);

            //標(biāo)記此頂點(diǎn)已經(jīng)被訪問
            graph.isTrav[vertex] = true;

            //輸出頂點(diǎn)
            Console.Write(" ->" + graph.vertex[vertex]);

            //廣度遍歷頂點(diǎn)的鄰接點(diǎn)
            while (queue.Count != 0)
            {
                var temp = queue.Dequeue();

                //遍歷矩陣的橫坐標(biāo)
                for (int i = 0; i graph.vertexNum; i++)
                {
                    if (!graph.isTrav[i] graph.edges[temp, i] != 0)
                    {
                        graph.isTrav[i] = true;

                        queue.Enqueue(i);

                        //輸出未被訪問的頂點(diǎn)
                        Console.Write(" ->" + graph.vertex[i]);
                    }
                }
            }
        }
        #endregion

        #region 深度優(yōu)先
        /// summary>
/// 深度優(yōu)先
/// /summary>
/// param name="graph">/param>
        public void DFSTraverse(MatrixGraph graph)
        {
            //訪問標(biāo)記默認(rèn)初始化
            for (int i = 0; i graph.vertexNum; i++)
            {
                graph.isTrav[i] = false;
            }

            //遍歷每個(gè)頂點(diǎn)
            for (int i = 0; i graph.vertexNum; i++)
            {
                //廣度遍歷未訪問過的頂點(diǎn)
                if (!graph.isTrav[i])
                {
                    DFSM(ref graph, i);
                }
            }
        }

        #region 深度遞歸的具體算法
        /// summary>
/// 深度遞歸的具體算法
/// /summary>
/// param name="graph">/param>
/// param name="vertex">/param>
        public void DFSM(ref MatrixGraph graph, int vertex)
        {
            Console.Write("->" + graph.vertex[vertex]);

            //標(biāo)記為已訪問
            graph.isTrav[vertex] = true;

            //要遍歷的六個(gè)點(diǎn)
            for (int i = 0; i graph.vertexNum; i++)
            {
                if (graph.isTrav[i] == false graph.edges[vertex, i] != 0)
                {
                    //深度遞歸
                    DFSM(ref graph, i);
                }
            }
        }
        #endregion
        #endregion

        #region prim算法獲取最小生成樹
        /// summary>
/// prim算法獲取最小生成樹
/// /summary>
/// param name="graph">/param>
        public void Prim(MatrixGraph graph, out int sum)
        {
            //已訪問過的標(biāo)志
            int used = 0;

            //非鄰接頂點(diǎn)標(biāo)志
            int noadj = -1;

            //定義一個(gè)輸出總權(quán)值的變量
            sum = 0;

            //臨時(shí)數(shù)組,用于保存鄰接點(diǎn)的權(quán)值
            int[] weight = new int[graph.vertexNum];

            //臨時(shí)數(shù)組,用于保存頂點(diǎn)信息
            int[] tempvertex = new int[graph.vertexNum];

            //取出鄰接矩陣的第一行數(shù)據(jù),也就是取出第一個(gè)頂點(diǎn)并將權(quán)和邊信息保存于臨時(shí)數(shù)據(jù)中
            for (int i = 1; i graph.vertexNum; i++)
            {
                //保存于鄰接點(diǎn)之間的權(quán)值
                weight[i] = graph.edges[0, i];

                //等于0則說明V1與該鄰接點(diǎn)沒有邊
                if (weight[i] == short.MaxValue)
                    tempvertex[i] = noadj;
                else
                    tempvertex[i] = int.Parse(graph.vertex[0]);
            }

            //從集合V中取出V1節(jié)點(diǎn),只需要將此節(jié)點(diǎn)設(shè)置為已訪問過,weight為0集合
            var index = tempvertex[0] = used;
            var min = weight[0] = short.MaxValue;

            //在V的鄰接點(diǎn)中找權(quán)值最小的節(jié)點(diǎn)
            for (int i = 1; i graph.vertexNum; i++)
            {
                index = i;
                min = short.MaxValue;

                for (int j = 1; j graph.vertexNum; j++)
                {
                    //用于找出當(dāng)前節(jié)點(diǎn)的鄰接點(diǎn)中權(quán)值最小的未訪問點(diǎn)
                    if (weight[j] min tempvertex[j] != 0)
                    {
                        min = weight[j];
                        index = j;
                    }
                }
                //累加權(quán)值
                sum += min;

                Console.Write("({0},{1})  ", tempvertex[index], graph.vertex[index]);

                //將取得的最小節(jié)點(diǎn)標(biāo)識(shí)為已訪問
                weight[index] = short.MaxValue;
                tempvertex[index] = 0;

                //從最新的節(jié)點(diǎn)出發(fā),將此節(jié)點(diǎn)的weight比較賦值
                for (int j = 0; j graph.vertexNum; j++)
                {
                    //已當(dāng)前節(jié)點(diǎn)為出發(fā)點(diǎn),重新選擇最小邊
                    if (graph.edges[index, j] weight[j] tempvertex[j] != used)
                    {
                        weight[j] = graph.edges[index, j];

                        //這里做的目的將較短的邊覆蓋點(diǎn)上一個(gè)節(jié)點(diǎn)的鄰接點(diǎn)中的較長(zhǎng)的邊
                        tempvertex[j] = int.Parse(graph.vertex[index]);
                    }
                }
            }
        }
        #endregion

        #region dijkstra求出最短路徑
        /// summary>
/// dijkstra求出最短路徑
/// /summary>
/// param name="g">/param>
        public void Dijkstra(MatrixGraph g)
        {
            int[] weight = new int[g.vertexNum];

            int[] path = new int[g.vertexNum];

            int[] tempvertex = new int[g.vertexNum];

            Console.WriteLine("\n請(qǐng)輸入源點(diǎn)的編號(hào):");

            //讓用戶輸入要遍歷的起始點(diǎn)
            int vertex = int.Parse(Console.ReadLine()) - 1;

            for (int i = 0; i g.vertexNum; i++)
            {
                //初始賦權(quán)值
                weight[i] = g.edges[vertex, i];

                if (weight[i] short.MaxValue weight[i] > 0)
                    path[i] = vertex;

                tempvertex[i] = 0;
            }

            tempvertex[vertex] = 1;
            weight[vertex] = 0;

            for (int i = 0; i g.vertexNum; i++)
            {
                int min = short.MaxValue;

                int index = vertex;

                for (int j = 0; j g.vertexNum; j++)
                {
                    //頂點(diǎn)的權(quán)值中找出最小的
                    if (tempvertex[j] == 0 weight[j] min)
                    {
                        min = weight[j];
                        index = j;
                    }
                }

                tempvertex[index] = 1;

                //以當(dāng)前的index作為中間點(diǎn),找出最小的權(quán)值
                for (int j = 0; j g.vertexNum; j++)
                {
                    if (tempvertex[j] == 0 weight[index] + g.edges[index, j] weight[j])
                    {
                        weight[j] = weight[index] + g.edges[index, j];
                        path[j] = index;
                    }
                }
            }

            Console.WriteLine("\n頂點(diǎn){0}到各頂點(diǎn)的最短路徑為:(終點(diǎn) 源點(diǎn)) " + g.vertex[vertex]);

            //最后輸出
            for (int i = 0; i g.vertexNum; i++)
            {
                if (tempvertex[i] == 1)
                {
                    var index = i;

                    while (index != vertex)
                    {
                        var j = index;
                        Console.Write("{0} ", g.vertex[index]);
                        index = path[index];
                    }
                    Console.WriteLine("{0}\n", g.vertex[index]);
                }
                else
                {
                    Console.WriteLine("{0} - {1}: 無路徑\n", g.vertex[i], g.vertex[vertex]);
                }
            }
        }
        #endregion
    }
}

 

算法速成系列至此就全部結(jié)束了,公司給我們的算法培訓(xùn)也于上周五結(jié)束,呵呵,趕一下同步。最后希望大家能對(duì)算法重視起來,

學(xué)好算法,終身收益。

您可能感興趣的文章:
  • 算法系列15天速成 第十四天 圖【上】
  • 算法系列15天速成——第十三天 樹操作【下】
  • 算法系列15天速成 第十二天 樹操作【中】
  • 算法系列15天速成 第十一天 樹操作(上)
  • 算法系列15天速成 第十天 棧
  • 算法系列15天速成 第八天 線性表【下】
  • 算法系列15天速成 第九天 隊(duì)列
  • 算法系列15天速成 第七天 線性表【上】
  • 算法系列15天速成 第六天 五大經(jīng)典查找【下】
  • 算法系列15天速成 第五天 五大經(jīng)典查找【中】
  • 算法系列15天速成 第四天 五大經(jīng)典查找【上】
  • 算法系列15天速成 第三天 七大經(jīng)典排序【下】
  • 算法系列15天速成 第二天 七大經(jīng)典排序【中】
  • 算法系列15天速成 第一天 七大經(jīng)典排序【上】

標(biāo)簽:內(nèi)蒙古 日照 宜賓 定州 96 巴彥淖爾 防城港 山南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《算法系列15天速成——第十五天 圖【下】(大結(jié)局)》,本文關(guān)鍵詞  算法,系列,15天,速成,第十五,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《算法系列15天速成——第十五天 圖【下】(大結(jié)局)》相關(guān)的同類信息!
  • 本頁收集關(guān)于算法系列15天速成——第十五天 圖【下】(大結(jié)局)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    国产成人福利网站| 夜夜摸夜夜操| 午夜先锋成人动漫在线| 欧美在线关看| 韩国中文字幕在线| 国产精品毛片久久久久久久| 午夜精品在线视频| 国精产品一区二区| 日韩一区av在线| 午夜毛片在线观看| 黄色的视频在线观看| 亚洲视频在线观看视频| 欧美午夜xxx| 好吊妞视频这里有精品| 极品尤物av久久免费看| 久久久久综合| 无码人妻精品一区二区蜜桃色欲| 男女爱爱视频网站| 日韩精品在线观看一区| 一区二区激情小说| 亚洲天堂视频在线播放| 日韩欧美国产成人一区二区| 国产一区二区在线视频你懂的| 超碰个人在线| 黄色免费观看| 欧美精品一区二区久久婷婷| 国产女主播喷水视频在线观看| 素人一区二区三区| 亚洲三区四区| 黄网站在线观| 91av视频在线观看| 免费人成黄页在线观看忧物| 日本中文字幕有码| 唐人社导航福利精品| 日韩少妇视频| 亚洲爆乳无码专区| 欧美黄网站色视频| 美女国产一区二区| 亚洲黄色免费在线观看| 欧美另类69精品久久久久9999| 日韩在线观看免| 7777精品伊人久久久大香线蕉经典版下载| 日韩成人在线电影| 一区二区三区成人精品| 亚洲一区第一页| 国产午夜精品视频免费不卡69堂| 亚洲欧美自偷自拍| 超碰在线最新网址| 色视频在线播放| 亚洲精品乱码久久久久久久久久久久| 精品高清久久| 中文字幕免费视频观看| 中文字幕一区二区三区电影| **精品中文字幕一区二区三区| 亚洲综合精品国产一区二区三区| 天堂社区日本电影超碰| 久久精品色综合| 色一情一伦一子一伦一区| 最新国产中文字幕| 91精品免费久久久久久久久| 欧美国产一区二区在线观看| 人人妻人人澡人人爽| 日韩在线观看免费高清完整版| 黄色欧美网站| 日本久久久久久久久| 美女一区二区三区视频| 毛毛毛毛毛毛毛片123| 白白色在线发布| 91精品国产乱码久久久张津瑜| 免费黄色av片| 中文字幕电影一区| 亚洲日本在线视频观看| 午夜精品久久久久久久久久蜜桃| 国产精品国产三级国产aⅴ中文| 五月天婷婷导航| 日韩不卡的av| 亚洲精品午夜精品| 欧美成人精品网站| 欧美一级视频在线播放| 玛雅亚洲电影| 麻豆一区产品精品蜜桃的特点| 国产亚洲精品日韩| 国产无遮挡在线观看| 欧美一区高清| 精品黄色免费中文电影在线播放| 亚洲中文字幕久久精品无码喷水| 欧美大胆a人体大胆做受| 亚洲 另类 春色 国产| 亚洲最大视频网| 亚洲精品国产九九九| 欧美日韩在线二区| 亚洲精品视频自拍| 成人影院在线免费观看| 国产欧美日韩精品一区二区三区| 久久亚洲成人| 亚洲欧美另类日韩| 99久久99| 992tv在线观看免费进| 久久久久久欧美| 精品影片在线观看的网站| 欧美熟乱第一页| 久久国产尿小便嘘嘘| 三上悠亚在线一区二区| 国产一区二区在线观看免费视频| 精品视频在线视频| 欧美一区三区| 成人欧美一区二区三区在线| 91精品产国品一二三产区| 蜜桃成人365av| 97在线视频精品| 性生活免费网站| 精品精品国产高清a毛片牛牛| 国产精品久久久久久网站| 男人草女人视频| 日本不卡视频| 久草视频这里只有精品| 91精品啪在线观看国产81旧版| 日韩中文字幕视频| 国产成人a亚洲精品| 激情五月婷婷小说| 成人免费视频国产免费麻豆| 午夜一区二区三区免费| 国产69精品久久久久9| 91淫黄看大片| 欧美在线精品一区二区三区| 久久久久久久久久伊人| 男人添女人下面高潮视频| 黄色网页在线观看| 日韩av一二区| 97在线视频观看| 99热这里只有精品在线播放| 日韩成人午夜精品| 欧美18一19xxx性| 欧美jizzhd欧美| 亚洲大片av| 小舞被吸乳羞羞网站视频| 欧洲成人在线观看| 毛片在线播放视频| 超碰免费在线播放| a√免费观看在线网址www| 欧美性感一类影片在线播放| 中文精品久久久久人妻不卡| 成人av网址在线| 亚洲一级大片| 国产精品一级二级三级| 亚洲综合精品自拍| h在线观看网站| 91亚洲精品久久久蜜桃网站| 成人开心激情| 九草视频在线观看| 亚洲不卡视频| jizzjizz亚洲| jizz欧美性20| 黄色小视频免费网站| 樱桃视频在线观看一区| 精品国产aⅴ一区二区三区东京热| 中文字幕一区二区三区乱码图片| shkd中文字幕久久在线观看| 欧美男人天堂| 久久精品色妇熟妇丰满人妻| 91国产精品视频在线| 国产网站欧美日韩免费精品在线观看| 欧美剧在线免费观看网站| 欧美一区二粉嫩精品国产一线天| 日本美女视频网站| 亚洲美女av在线| 成视人a免费观看视频| 国产黄色片视频| 欧美在线视频在线播放完整版免费观看| 国产巨乳在线观看| 四虎精品欧美一区二区免费| 国产精品自产拍在线观看2019| 久久久久久av无码免费看大片| 日本999视频| 91午夜视频| 视频一区视频二区视频三区高| 美女扒开大腿让男人桶| 久久精品久久精品亚洲人| 成人综合久久| 国产精品久久久久久久| 黄色片免费在线观看| 一级一片免费看| 九九久久综合网站| 精品国产伦一区二区三区观看方式| 男人网站在线观看| 午夜国产精品视频免费体验区| 中文字幕精品久久| 国产三区视频在线观看| 一区二区三区在线视频观看58| 国产精品av免费观看| h视频免费高清在线观看| 亚洲欧美999| 国产黄色精品视频| 女人床在线观看| 国产精品无人区| 成人涩涩免费视频| 一级黄色片在线免费观看| 岛国av免费在线观看| 国产色婷婷在线| 欧美综合久久久| 欧美国产综合视频| 国产乱码精品一区二区三区忘忧草| 成人av在线播放观看| 高清精品xnxxcom| 亚洲AV无码片久久精品| 国产成人手机在线| 韩国欧美一区二区| 国产一区二区91| 91精品国产色综合久久不卡电影| 轻轻操 在线观看| 亚洲欧美综合另类中字| 91精品国产综合久久久久久| аⅴ成人天堂中文在线| 日韩天堂在线| 黄色网战入口| 亚洲三级免费电影| av黄色一级| 日本久久久网站| 比比资源-先锋影音资源站| 日韩电影在线免费观看| 欧美日韩一级片在线观看| 婷婷精品视频| 国产精品99精品无码视| 美女喷白浆视频| 精品国产av 无码一区二区三区| 日本中文字幕高清视频| 色综合久久88色综合天天提莫| 亚洲欧美在线成人| 清纯粉嫩极品夜夜嗨av| 糖心vlog在线免费观看| 成人欧美大片| 天堂资源在线观看| 久久精品一区二| 日本美女一区二区三区| 国产美女久久| 无码人妻精品一区二区三区夜夜嗨| 欧美日产一区二区三区在线观看| 欧美特黄一级| 久久综合久久综合亚洲| 日本黄视频网站| 96成人在线视频| 亚洲av无码一区二区三区在线| 调教一区二区| 成人免费黄色网页| 国产91在线播放九色快色| 日韩欧美国产精品一区二区三区| 国产亚洲欧洲高清一区| eeuss影院www天堂免费| 传媒视频在线| 波多野结衣的一区二区三区| 国产日韩在线精品av| freemovies性欧美| 中文字幕网站在线观看| 欧美两根一起进3p做受视频| 欧美极度另类videos高清| 色av成人天堂桃色av| 99精品国产福利在线观看免费| 外国成人毛片| 日韩精品视频免费播放| 91黄色免费网站| 日韩欧美国产免费播放| free性m.freesex欧美| 精品久久国产97色综合| 少妇久久久久久被弄到高潮| 国产天堂视频在线观看| 欧美黄色免费看| 三级全黄做爰视频| 一炮成瘾1v1高h| 国产精品一区二区三区乱码| 性xxxxxxxxx| 亚洲综合激情五月| 可以看av的网址| 青柠在线免费观看| 一本色道久久hezyo无码| 一本大道香蕉8中文在线视频| 欧美成人一二三区| 欧美日韩免费精品| 精品人妻伦一区二区三区久久| 大桥未久在线播放| 国产精品视频久久久久久| 国产欧美一区二区三区在线观看视频| 亚洲综合五月| yourporn久久国产精品| 欧美特黄一区| 中文在线a天堂| 好吊一区二区三区| 日韩精品一区二区三区不卡| 亚洲欧美日韩另类精品一区二区三区| 亚洲国产一区二区三区在线播| 午夜视黄欧洲亚洲| 久久久久久亚洲中文字幕无码| 欧美12一14sex性hd| 男人添女荫道口女人有什么感觉| 欧美一区二区黄片| 国产免费黄色片| 欧美日韩在线高清| 国产精品久久久久天堂| 久久精品夜色噜噜亚洲aⅴ| 欧美另类极品videosbest视| 精品久久人妻av中文字幕| 亚洲欧美综合v| 日韩在线观看免费高清完整版| 亚洲国产综合在线看不卡| 日本人妻一区二区三区| 91精品天堂福利在线观看| 亚洲人一二三区| 国产视频第一区| 欧美日韩精品欧美日韩精品一| 亚洲欧美日本一区二区| 最近中文字幕av| 51vv免费精品视频一区二区| 亚洲综合在线视频| 日韩中文在线中文网三级| 欧美日韩在线观看视频小说| 91色视频在线导航| 亚洲精品亚洲人成人网在线播放| 免费av在线电影| 不卡视频在线观看| 亚洲av无码专区在线| 男人看的污网站| 蜜桃一级网站.| 天堂免费在线视频| 波多视频一区| 欧美日韩小视频| 精品久久97| 97香蕉久久超级碰碰高清版| 国产v亚洲v天堂无码久久久| 欧美三级自拍|