Chinaunix首页 | 论坛 | 博客
  • 博客访问: 269241
  • 博文数量: 138
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 971
  • 用 户 组: 普通用户
  • 注册时间: 2015-03-03 10:05
文章分类

全部博文(138)

文章存档

2016年(1)

2015年(137)

我的朋友

分类: C/C++

2015-04-01 18:42:26

图1为线性表(ZHAO, QIAN, SUN, LI, ZHOU, WU, ZHENG, WANG)的逻辑状态。头指针 指示链表中第一个结点(即第一个数据元素的存储映像)的存储位置。同时,由于最后一个数据元素没有直接后继,则线性链表中最后一个结点的指针为“空”(NULL)。

图1 线性链表的逻辑状态

由上述描述可见,单链表可由头指针来唯一确定,在C语言中可用“结构指针”来描述。

  1. //-----线性表的单链表存储结构-----  
  2. typedef struct LNode{  
  3.     ElemType   data;  
  4.     struct LNode  *next;  
  5. }LNode, *LinkList;  


有时在单链表的第一个结点之前附设一个结点,称之为头结点  头结点的数据域可以不存储任何信息,也可以存储如线性表长度等类的附加信息,头结点的指针域存储指向第一个结点的指针(即第一个元素结点的存储位置)。如图2(a)所示,此时,单链表的头指针指向头结点。若线性表为空,则头结点的指针域为“空”,如图2(b)所示。

图2 带头结点的单链表   (a)非空表;(b)空表

阅读(766) | 评论(0) | 转发(0) |
0

上一篇:链表的游标实现

下一篇:栈C实现

给主人留下些什么吧!~~