数据结构--BFS求最短路

数据结构–BFS求最短路

数据结构--BFS求最短路_第1张图片

BFS求⽆权图的单源最短路径

注:⽆权图可以视为⼀种特殊的带权图,只是每条边的权值都为1

数据结构--BFS求最短路_第2张图片

以 2 为 b e g i n 位置 以2为begin位置 2begin位置

数据结构--BFS求最短路_第3张图片
数据结构--BFS求最短路_第4张图片
数据结构--BFS求最短路_第5张图片

代码实现

//求顶点u到其他顶点的最短路径
void BFS_MIN_Distance(Graph G, int u)
{
    //d[i]表示从u到i结点的最短路径
    for(i = 0; i < G.vexnum; ++i)
    {
        d[i] = inf;  //初始化路径长度
        path[i] = -1; //最短路径从哪个顶点过来
    }
    d[u] = 0;
    visited[u] = TRUE;
    EnQueue(Q, u);
    while(!isEmpty(Q))//BFS算法主过程
    {
        DeQueue(Q, u); //队头元素u出队
        for(w = FirstNeighbor(G, u); w >= 0; w = NextNeighbor(G, u, w))
        {
            if(!visited[w])//w为u的尚未访问的邻接顶点
            {

                d[w] = d[u] + 1; //路径长度加1
                path[w] = u; //最短路径应从u到W
                visited[w] = TRUE; //设已访问标记
                EnQueue(Q, w); //顶点w入队
            }
        }

    }
}

上图最终 d[]、 path[]、 visited[] 的情况

将其生成⼴度优先⽣成树

数据结构--BFS求最短路_第6张图片

就是对BFS的⼩修改,在visit⼀个顶点时,修改
其最短路径⻓度 d[ ] 并在 path[ ] 记录前驱结点

2到8的最短路径⻓度 = d[8] = 3
通过path数组可知,2到8的最短路径为: 2 → 6 → 7 → 8 2\to6\to7\to8 2678

你可能感兴趣的:(408数据结构,数据结构,宽度优先,算法,c++,图论,最短路,单源最短路)