第12周、项目4 ㈡—利用遍历思想求解图问题

原创 2015年11月20日 09:05:52

问题及代码:

******程序中graph.h是图存储结构的“算法库”中的头文件,详情请单击链接…******

⑥求不带权连通图G中从顶点u到顶点v的一条最短路径。

#include <stdio.h>
#include <malloc.h>
#include "graph.h"

typedef struct
{
    int data;                   //顶点编号
    int parent;                 //前一个顶点的位置
} QUERE;                        //非环形队列类型

void ShortPath(ALGraph *G,int u,int v)
{
    //输出从顶点u到顶点v的最短逆路径
    ArcNode *p;
    int w,i;
    QUERE qu[MAXV];             //非环形队列
    int front=-1,rear=-1;       //队列的头、尾指针
    int visited[MAXV];
    for (i=0; i<G->n; i++)      //访问标记置初值0
        visited[i]=0;
    rear++;                     //顶点u进队
    qu[rear].data=u;
    qu[rear].parent=-1;
    visited[u]=1;
    while (front!=rear)         //队不空循环
    {
        front++;                //出队顶点w
        w=qu[front].data;
        if (w==v)               //找到v时输出路径之逆并退出
        {
            i=front;            //通过队列输出逆路径
            while (qu[i].parent!=-1)
            {
                printf("%2d ",qu[i].data);
                i=qu[i].parent;
            }
            printf("%2d\n",qu[i].data);
            break;
        }
        p=G->adjlist[w].firstarc;   //找w的第一个邻接点
        while (p!=NULL)
        {
            if (visited[p->adjvex]==0)
            {
                visited[p->adjvex]=1;
                rear++;             //将w的未访问过的邻接点进队
                qu[rear].data=p->adjvex;
                qu[rear].parent=front;
            }
            p=p->nextarc;           //找w的下一个邻接点
        }
    }
}

int main()
{
    ALGraph *G;
    int A[9][9]=
    {
        {0,1,1,0,0,0,0,0,0},
        {0,0,0,1,1,0,0,0,0},
        {0,0,0,0,1,1,0,0,0},
        {0,0,0,0,0,0,1,0,0},
        {0,0,0,0,0,1,1,0,0},
        {0,0,0,0,0,0,0,1,0},
        {0,0,0,0,0,0,0,1,1},
        {0,0,0,0,0,0,0,0,1},
        {0,0,0,0,0,0,0,0,0}
    };  //请画出对应的有向图
    ArrayToList(A[0], 9, G);
    ShortPath(G,0,7);
    return 0;
}

附:测试用图结构

运行结果:

⑦求不带权连通图G中,距离顶点v最远的顶点k

#include <stdio.h>
#include <malloc.h>
#include "graph.h"

int Maxdist(ALGraph *G,int v)
{
    ArcNode *p;
    int i,j,k;
    int Qu[MAXV];               //环形队列
    int visited[MAXV];              //访问标记数组
    int front=0,rear=0;             //队列的头、尾指针
    for (i=0; i<G->n; i++)          //初始化访问标志数组
        visited[i]=0;
    rear++;
    Qu[rear]=v;                 //顶点v进队
    visited[v]=1;               //标记v已访问
    while (rear!=front)
    {
        front=(front+1)%MAXV;
        k=Qu[front];                //顶点k出队
        p=G->adjlist[k].firstarc;       //找第一个邻接点
        while (p!=NULL)             //所有未访问过的相邻点进队
        {
            j=p->adjvex;            //邻接点为顶点j
            if (visited[j]==0)          //若j未访问过
            {
                visited[j]=1;
                rear=(rear+1)%MAXV;
                Qu[rear]=j; //进队
            }
            p=p->nextarc;           //找下一个邻接点
        }
    }
    return k;
}

int main()
{
    ALGraph *G;
    int A[9][9]=
    {
        {0,1,1,0,0,0,0,0,0},
        {0,0,0,1,1,0,0,0,0},
        {0,0,0,0,1,1,0,0,0},
        {0,0,0,0,0,0,1,0,0},
        {0,0,0,0,0,1,1,0,0},
        {0,0,0,0,0,0,0,1,0},
        {0,0,0,0,0,0,0,1,1},
        {0,0,0,0,0,0,0,0,1},
        {0,0,0,0,0,0,0,0,0}
    };  //请画出对应的有向图
    ArrayToList(A[0], 9, G);
    printf("离顶点0最远的顶点:%d",Maxdist(G,0));
    return 0;
}

附:测试用图结构

运行结果:

版权声明:本文为博主原创文章,未经博主允许不得转载。

第11周 【项目4 - 利用遍历思想求解图问题】

/*   *Copyright  (c)2017,烟台大学计算机与控制工程学院       *All rights reservrd.            *作者:李欣豪  *完成时间:2017年1...
  • qq_39837019
  • qq_39837019
  • 2017年11月22日 10:47
  • 70

第11周项目4 - 利用遍历思想求解图问题

假设图G采用邻接表存储,分别设计实现以下要求的算法,要求用区别于示例中的图进行多次测试,通过观察输出值,掌握相关问题的处理方法。   (1)设计一个算法,判断顶点u到v是否有简单路径 ...
  • alicia6137
  • alicia6137
  • 2017年11月13日 21:18
  • 49

第11周 【项目4 - 利用遍历思想求解图问题】

1、是否有简单路径?  问题:假设图G采用邻接表存储,设计一个算法,判断顶点u到v是否有简单路径。 #include #include #include "graph.h" int visit...
  • qq_37151886
  • qq_37151886
  • 2017年12月16日 15:44
  • 46

第12周项目4 - 利用遍历思想求解图问题(4)

问题及代码: /* * Copyright (c)2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称:main.cpp * 作 者:何大冰 * ...
  • big_ice
  • big_ice
  • 2016年11月17日 11:00
  • 106

第11周【项目4 - 利用遍历思想求解图问题】

假设图G采用邻接表存储,设计实现以下要求的算法,要求用区别于示例中的图进行多次测试,通过观察输出值,掌握相关问题的处理方法。  点击打开图的基本算法库graph.h等 (1)设计一个算法,判断...
  • tingke_
  • tingke_
  • 2017年12月07日 11:06
  • 21

第12周项目4 利用遍历思想求解图问题

问题及代码: 文件名称:main.cpp  graph.cpp  graph.h 作者:郑孚嘉 问题描述:假设图G采用邻接表存储,分别设计实现以下要求的算法,要求用区别于示例中的图进行多次测试,通过观...
  • qq_27910389
  • qq_27910389
  • 2015年12月14日 11:05
  • 176

第12周项目4利用遍历思想求解图问题(1-5)

问题及代码: (1) /* 文件名称:项目4.cpp 作者:孙洁 完成日期: 2015.12.14 问题描述: 假设图G采用邻接表存储,分别设计实现以下要求的算法,要求用区别于示例中的图进行...
  • sunjiesj
  • sunjiesj
  • 2015年12月14日 17:15
  • 237

第12周、项目4 ㈠—利用遍历思想求解图问题

问题及代码: /* *Copyright(c) 2015,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:test.cpp *作 者:焦梦真 *完...
  • MoCulison
  • MoCulison
  • 2015年11月20日 08:43
  • 339

第12周项目4利用遍历思想求解图问题3

问题及代码: /* * * * * *烟台大学计算机与控制工程学院 *作者:刘熠 *时间:2015年11月23日 * * * * ...
  • liuyi6666
  • liuyi6666
  • 2015年11月23日 16:45
  • 152

第12周项目4-利用遍历思想求解图问题(4)

/* Copyright (c)2016,烟台大学计算机与控制工程学院 All rights reserved. 文件名称:第十二周项目4 - 利用遍历思想求解图问题.cpp 作 者:孟...
  • qq_36000007
  • qq_36000007
  • 2016年11月17日 11:17
  • 55
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:第12周、项目4 ㈡—利用遍历思想求解图问题
举报原因:
原因补充:

(最多只允许输入30个字)