知识大全 单链表
Posted 结点
篇首语:人生遇到的每个人,出场顺序很重要,很多人如果换个时间认识,就会有不同的结局。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 单链表相关的知识,希望对你有一定的参考价值。
单链表 链接存储方法 链接方式存储的线性表简称为链表(Linked List) 链表的具体存储表示为 ① 用一组任意的存储单元来存放线性表的结点(这组存储单元既可以是连续的 也可以是不连续的) ② 链表中结点的逻辑次序和物理次序不一定相同 为了能正确表示结点间的逻辑关系 在存储每个结点值的同时 还必须存储指示其后继结点的地址(或位置)信息(称为指针(pointer)或链(link))注意 链式存储是最常用的存储方式之一 它不仅可用来表示线性表 而且可用来表示各种非线性的数据结构
链表的结点结构 ┌──┬──┐ │data│next│ └──┴──┘ data域 存放结点值的数据域 next域 存放结点的直接后继的地址(位置)的指针域(链域)注意 ①链表通过每个结点的链域将线性表的n个结点按其逻辑顺序链接在一起的 ②每个结点只有一个链域的链表称为单链表(Single Linked List) 【例】线性表(bat cat eat fat hat jat lat mat)的单链表示如示意图
头指针head和终端结点指针域的表示 单链表中每个结点的存储地址是存放在其前趋结点next域中 而开始结点无前趋 故应设头指针head指向开始结点 注意 链表由头指针唯一确定 单链表可以用头指针的名字来命名 【例】头指针名是head的链表可称为表head 终端结点无后继 故终端结点的指针域为空 即NULL
单链表的一般图示法 由于我们常常只注重结点间的逻辑顺序 不关心每个结点的实际位置 可以用箭头来表示链域中的指针 线性表(bat cat fat hat jat lat mat)的单链表就可以表示为下图形式
单链表类型描述 typedef char DataType; //假设结点的数据域类型为字符 typedef struct node //结点类型定义 DataType data; //结点的数据域 struct node *next;//结点的指针域 ListNode; typedef ListNode *LinkList; ListNode *p; LinkList head; 注意 ①LinkList和ListNode *是不同名字的同一个指针类型(命名的不同是为了概念上更明确) ②LinkList类型的指针变量head表示它是单链表的头指针 ③ListNode *类型的指针变量p表示它是指向某一结点的指针 指针变量和结点变量
┌────┬────────────┬─────────────┐ │ │ 指针变量 │ 结点变量 │├────┼────────────┼─────────────┤│ 定义 │在变量说明部分显式定义 │在程序执行时 通过标准 ││ │ │函数malloc生成 │├────┼────────────┼─────────────┤│ 取值 │ 非空时 存放某类型结点 │实际存放结点各域内容 ││ │的地址 │ │├────┼────────────┼─────────────┤│操作方式│ 通过指针变量名访问 │ 通过指针生成 访问和释放 │└────┴────────────┴─────────────┘ ①生成结点变量的标准函数 p=( ListNode *)malloc(sizeof(ListNode)) //函数malloc分配一个类型为ListNode的结点变量的空间 并将其首地址放入指针变量p中②释放结点变量空间的标准函数 free(p) //释放p所指的结点变量空间③结点分量的访问 利用结点变量的名字*p访问结点分量 方法一 (*p) data和(*p) next 方法二 p ﹥data和p ﹥next④指针变量p和结点变量*p的关系 指针变量p的值——结点地址 结点变量*p的值——结点内容 (*p) data的值——p指针所指结点的data域的值 (*p) next的值——*p后继结点的地址 *((*p) next)——*p后继结点注意 ① 若指针变量p的值为空(NULL) 则它不指向任何结点 此时 若通过*p来访问结点就意味着访问一个不存在的变量 从而引起程序的错误 ② 有关指针类型的意义和说明方式的详细解释 【参考C语言的有关资料】
cha138/Article/program/sjjg/201311/23687相关参考
单链表的运算 建立单链表 假设线性表中结点的数据类型是字符我们逐个输入这些字符型的结点并以换行符\\n为输入条件结束标志符动态地建立单链表 的常用方法有如下两种 ()头插法建表 ①算法思
销毁单链表 单链表被构造使用完后由于其结点均为动态分配的内存空间所以必须要销毁以释放空间否则会造成申请的内存不能释放单链表的销毁操作是创建操作的逆运算由于要修改单链表的头指针的指针变量所以要将头
图双向链表中的结点删除 双向链表的结束条件和单链表相同双向循环链表的结束条件和单向循环链表的结束条件相同 静态链表 根据上节单链表的知识用单链表表示线性表时其结点空间是在运行时根据需要动态分
单链表 链接存储方法 链接方式存储的线性表简称为链表(LinkedList) 链表的具体存储表示为 ①用一组任意的存储单元来存放线性表的结点(这组存储单元既可以是连续的也可以是不连续的)
单链表基本运算的实现 创建空单链表 链表与顺序表不同它是一种动态管理的存储结构链表中的每个结点占用的存储空间不是预先分配而是运行时系统根据需求生成的因此建立空单链表就是建立一个带头结点的空表该
求表长 由于单链表采用离散的存储方式并且没有显示表长的存储信息因此要求出单链表的表长必须将单链表遍历一遍 算法思路设一个移动指针p和计数器count初始化后p指向头结点p后移一个结点count
循环链表 对于单链表而言最后一个结点的指针域是空指针如果将该链表头指针置入该指针域则使得链表头尾结点相连就构成了循环单链表(也称单循环链表)如图所示 > 图带头结点的单循环链表 对循环单链
C#单链表 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! usingSystem; using
单链表的查找运算()按序号查找①链表不是随机存取结构 在链表中即使知道被访问结点的序号i也不能像顺序表中那样直接按序号i访问结点而只能从链表的头指针出发顺链域nex