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

头结点是在链表的开始结点之前附加一个结点 它具有两个优点:
⒈由于开始结点的位置被存放在头结点的指针域中 所以在链表的第一个位置上的操作就和在表的其它位置上操作一致 无须进行
特殊处理;
⒉无论链表是否为空 其头指针都是指向头结点的非空指针(空表中头结点的指针域空) 因此空表和非空表的处理也就统一了
②带头结点的单链表
注意
头结点数据域的阴影表示该部分不存储信息 在有的应用中可用于存放表长等附加信息
③尾插法建带头结点链表算法
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- 上一篇
单链表时间复杂度 有个二级单链表,其中每个元素都含有一个指向一个单链表的指针。写程序把这个二级链表展开称一级单链表
有个二级单链表,其中每个元素都含有一个指向一个单链表的指针。写程序把这个二级链表展开称一级单链表 这个二级单链表只包括一些head u lic cla Li k { u lic Li k Next u
- 下一篇
分支节点的定义 即每个节点都有三个指向孩子结点的指针,请问:在这!
即每个节点都有三个指向孩子结点的指针,请问:在这 即每个节点都有三个指向孩子结点的指针,请问:在这, 一颗二叉树具有 个节点 用二叉链表存储时,其中有( )个指针用于指向孩子节点?1. 这个问题有点不
相关文章
- 线性表和链表的优缺点 线性表 - 链式存储结构- 单链表的运算(五)
- 线性表的数据结构 第四课:线性表的类型定义
- 线性表的数据结构有哪些 数据结构之线性表的链式存储[4]
- 线性表的数据结构有哪些 数据结构之线性表的逻辑结构[2]
- 线性表的链式存储结构与顺序存储 数据结构线性表之线性表的顺序存储结构[2]
- 双向链表与循环链表 数据结构 3.4 双向循环链表
- 线性表的链式存储结构与顺序存储 线性表 - 顺序存储结构 - 顺序表
- 具有线性结构的数据结构是 第一部分 线性存储结构[2]
- 链表和顺序表的区别 数据结构之顺序表上基本运算的实现[9]
- 线性表的链式存储结构与顺序存储 数据结构线性表之线性表的顺序存储结构[1]
爱学记

微信收款码
支付宝收款码