5.5 广义表的存储结构

 /* c5-5.h 广义表的头尾链表存储表示 */
 typedef enum{ATOM,LIST}ElemTag; /* ATOM==0:原子,LIST==1:子表 */
 typedef struct GLNode
 {
   ElemTag tag; /* 公共部分,用于区分原子结点和表结点 */
   union /* 原子结点和表结点的联合部分 */
   {
     AtomType atom; /* atom是原子结点的值域,AtomType由用户定义 */
     struct
     {
       struct GLNode *hp,*tp;
     }ptr; /* ptr是表结点的指针域,prt.hp和ptr.tp分别指向表头和表尾 */
   }a;
 }*GList,GLNode; /* 广义表类型 */

                                                                                                                          5.5 广义表的存储结构_第1张图片

 

5.5 广义表的存储结构_第2张图片

 

 /* c5-6.h 广义表的扩展线性链表存储表示 */
 typedef enum{ATOM,LIST}ElemTag; /* ATOM==0:原子,LIST==1:子表 */
 typedef struct GLNode1
 {
   ElemTag tag; /* 公共部分,用于区分原子结点和表结点 */
   union /* 原子结点和表结点的联合部分 */
   {
     AtomType atom; /* 原子结点的值域 */
     struct GLNode1 *hp; /* 表结点的表头指针 */
   }a;
   struct GLNode1 *tp; /* 相当于线性链表的next,指向下一个元素结点 */
 }*GList1,GLNode1; /* 广义表类型GList1是一种扩展的线性链表 */

5.5 广义表的存储结构_第3张图片

5.5 广义表的存储结构_第4张图片

你可能感兴趣的:(5.5 广义表的存储结构)