首页 > 其他 > 详细

图--十字链表-笔记

时间:2018-08-15 15:53:50      阅读:134      评论:0      收藏:0      [点我收藏+]

参考来源:大话数据结构。

对于有向图来说,邻接链表无法同时考虑到边的入度和出度问题,故有了十字链表这种数据结构。

顶点表 : 

data firstin firstout

其中firstin表示入边表头指针,表示该顶点的入边表中的第一个结点,firstout表示出边表头指针,指向该顶点的出边表的第一个结点。

边表:

tailvex headvex headlink

taillink

tailvex表示该边的起点在顶点表中的下标, headvex表示该边的终点在顶点表中的下标。headlink表示以headvex为终点的一系列边,taillink表示以tailvex为起点的一系列边。

代码如下:

/*********十字链表***********/

/************边表*************/
class EdgeNode 
{
public:
    int tailvex;   //该边的起点
    int headvex; //该边的终点
    int weight;   //边的权重
    EdgeNode *headlink = NULL; //入边表指针域
    EdgeNode *taillink = NULL; //出边表指针域
    EdgeNode(int _tail, int _head, int _weight) :
    tail(_tail), head(_head), weight(_weight) {};

};

/**********顶点表*******/
class VertexNode 
{
public:
    int data;
    EdgeNode *firstin; //入度
    EdgeNode *firstout;//出度
    //int pValue;
    //int dist = infty;
};

 

图--十字链表-笔记

原文:https://www.cnblogs.com/Shinered/p/9481855.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!