图的存储及基本操作 ---- 十字链表【有向图的一种链式存储结构】

1、

    》》 十字链表是有向图的一种链式存储结构。在十字链表中,对应于有向图中的每条弧

         有一个结点,对应于每个顶点也有一个结点。这些结点的结构如下:

             

             说明1: 弧结点

                    a. 尾域 tailvex  : 指示弧尾在图中的位置

                    b. 头域  headvex : 指示弧头在图中的位置

                    c. 链域 hlink : 指向弧头相同的下一条域

                    d. 链域 tlink : 指向弧尾相同的下一条域

                    e.  info : 指向该弧的相关信息

                   这样,弧头相同的弧在同一个链表上,弧尾相同的弧也在同一个链表上。

              

               说明2:顶点结点

                     a. data  域:存放顶点相关的数据信息,如顶点名称

                     b.  fitstin  : 指向以该顶点为弧头的第一个弧结点

                     c. firstout : 指向以该顶点为弧尾的第一个弧结点

 

   》》为有向图的十字链表表示法示例:【注意:顶点结点之间是“ 顺序存储 ”】

      

   》》图的十字链表存储结构定义如下:

  

 #define MaxVertexNum 100                      // 图中顶点数目的最大值
  typedef struct ArcNode{                       // 边表结点
      int tailvex , headvex;                    // 该弧的头尾结点
      struct ArcNode *hlink , *tlink ;          // 分别指向弧头相同和弧尾相同的结点
      // InfoType info;                         // 相关信息指针
  }ArcNode;

  typedef struct VNode {                        // 顶点表结点
       VertexType data;                         // 顶点信息
       ArcNode *firsttin , *firstout ;          // 指向第一条入弧和出弧
  }VNode;

  typedef struct{
       VNode xlist[MaxVertexNum];               // 邻接表
       int vexnum , arcnum ;                    // 图的顶点数和弧数
  }GLGraph;                                     // GLGraph 是以邻接表存储的图类型

  补充1:在十字链表中,既容易找到 Vi 为尾的弧,也容易找到 Vi 为头的弧,因而容易求得顶点的出度和入度。

       补充2: 图的十字链表表示不唯一的,但是一个十字链表表示确定一个图。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小达人Fighting

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值