线性表的链式存储结构与顺序存储 线性表 - 链式存储结构- 单链表的运算(三)
线性表 - 链式存储结构- 单链表的运算(三)
( ) 尾插法建带头结点的单链表
①头结点及作用

头结点是在链表的开始结点之前附加一个结点 它具有两个优点:
⒈由于开始结点的位置被存放在头结点的指针域中 所以在链表的第一个位置上的操作就和在表的其它位置上操作一致 无须进行
特殊处理;
⒉无论链表是否为空 其头指针都是指向头结点的非空指针(空表中头结点的指针域空) 因此空表和非空表的处理也就统一了
②带头结点的单链表
注意
头结点数据域的阴影表示该部分不存储信息 在有的应用中可用于存放表长等附加信息
③尾插法建带头结点链表算法
LinkList CreatListR (void)
{//用尾插法建立带头结点的单链表
char ch;
LinkList head=(ListNode *)malloc(sizeof(ListNode));//生成头结点
ListNode *s *r; //工作指针
r=head; // 尾指针初值也指向头结点
while((ch=getchar())!= n ){
s=(ListNode *)malloc(sizeof(ListNode));//生成新结点
s >data=ch; //将读入的数据放入新结点的数据域中
r >next=s;
r=s;
}
r >next=NULL;//终端结点的指针域置空 或空表的头结点指针域置空
return head;
}
注意
上述算法里 动态申请新结点空间时未加错误处理 这对申请空间极少的程序而言不会出问题 但在实用程序里 尤其是对空间需求
较大的程序 凡是涉及动态申请空间 一定要加入错误处理以防系统无空间可供分配
( ) 算法时间复杂度
lishixinzhi/Article/program/sjjg/201311/23309