前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >5.2.4 邻接多重表

5.2.4 邻接多重表

作者头像
week
发布2018-08-24 15:35:50
8610
发布2018-08-24 15:35:50
举报
文章被收录于专栏:用户画像用户画像

邻接多重表时无向表的另一种链式存储结构。

在邻接表中,容易求得顶点和边的各种信息,但在邻接表中求两个顶点之间是否存在边,或需要对边执行删除等操作时,需要分别在两个顶点的边表中遍历,效率较低。

与十字链表类似,在邻接多重表中,每一条边用一个结点表示,其结构如下图:

mark

ivex

ilink

jvex

jlink

info

其中,mark为标志域,可以用以标记该条表是否被搜索过;ivex和jvex为该边依附在两个顶点在图中的位置;ilink指向下一条依附于顶点ivex的边;jlink指向下一条依附于顶点jvex的边,info为指向和边相关的各种信息的指针域。

每一个顶点也用一个顶点表示,它由如下所示的两个域组成。

data

firstedge

其中,data域存储该顶点的相关信息,firstedge域指示第一条依附于该顶点的边。

在邻接多重表中,所有依附于同一顶点的边串联在同一链表中,由于每条边依附于两个顶点,则每个边结点同时链接在两个链表中。

代码语言:javascript
复制
#define MaxVertexNum 100//顶点数目的最大值

typedef struct ArcNode{//边表结点
    bool mark;//访问标记
    int ivex,jvex;//分别指向该弧的两个结点
    struct ArcNode *ilink,*jlink;//分别指向两个顶点的下一条边
    InforType info;//相关信息指针
}ArcNode;

typedef struct VNode{//顶点表结点
   VertextType data;//顶点信息
   ArcNode *firstedge;//指向第一条依附该顶点的边
}VNode;

typedef struct{
   VNode adjmulist[MaxVertexNum];//邻接表
   int vexnum ,arcnum;//图的顶点数和弧数
}AMLGraph;//AMLGraph 是以邻接表存储的图类型
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016年09月13日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档