知识大全 线性表 - 链式存储结构- 单链表的运算(三)
Posted 结点
篇首语:未曾哭过长夜的人,不足以语人生。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 线性表 - 链式存储结构- 单链表的运算(三)相关的知识,希望对你有一定的参考价值。
( ) 尾插法建带头结点的单链表
①头结点及作用
头结点是在链表的开始结点之前附加一个结点 它具有两个优点:
⒈由于开始结点的位置被存放在头结点的指针域中 所以在链表的第一个位置上的操作就和在表的其它位置上操作一致 无须进行
特殊处理;
⒉无论链表是否为空 其头指针都是指向头结点的非空指针(空表中头结点的指针域空) 因此空表和非空表的处理也就统一了
②带头结点的单链表
注意
头结点数据域的阴影表示该部分不存储信息 在有的应用中可用于存放表长等附加信息
③尾插法建带头结点链表算法
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;
注意
上述算法里 动态申请新结点空间时未加错误处理 这对申请空间极少的程序而言不会出问题 但在实用程序里 尤其是对空间需求
较大的程序 凡是涉及动态申请空间 一定要加入错误处理以防系统无空间可供分配
( ) 算法时间复杂度
cha138/Article/program/sjjg/201311/23309相关参考