知识大全 线性表 - 链式存储结构- 单链表的运算(四)
Posted 结点
篇首语:书籍是屹立在时间的汪洋大海中的灯塔本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 线性表 - 链式存储结构- 单链表的运算(四)相关的知识,希望对你有一定的参考价值。
单链表的查找运算
( )按序号查找
① 链表不是随机存取结构
在链表中 即使知道被访问结点的序号i 也不能像顺序表中那样直接按序号i访问结点 而只能从链表的头指针出发 顺链域
next逐个结点往下搜索 直至搜索到第i个结点为止 因此 链表不是随机存取结构
② 查找的思想方法
计数器j置为 后 扫描指针p指针从链表的头结点开始顺着链扫描 当p扫描下一个结点时 计数器j相应地加 当j=i时 指针
p所指的结点就是要找的第i个结点 而当p指针指为null且j≠i时 则表示找不到第i个结点
注意
头结点可看做是第 个结点
③具体算法实现
ListNode* GetNode(LinkList head int i)
//在带头结点的单链表head中查找第i个结点 若找到( ≤i≤n)
//则返回该结点的存储位置 否则返回NULL
int j;
ListNode *p;
p=head;j= ;//从头结点开始扫描
while(p >next&&j next为NULL或i=j为止
p=p >next;
j++;
if(i==j)
return p;//找到了第i个结点
else return NULL;//当i< 或i> 时 找不到第i个结点
④算法分析
算法中 while语句的终止条件是搜索到表尾或者满足j≥i 其频度最多为i 它和被寻找的位置有关 在等概率假设下 平均时间复杂度为
( ) 按值查找
①思想方法
从开始结点出发 顺着链逐个将结点的值和给定值key作比较 若有结点的值与key相等 则返回首次找到的其值为key的结点的存储
位置;否则返回NULL
②具体算法实现
ListNode* LocateNode (LinkList head DataType key)
//在带头结点的单链表head中查找其值为key的结点
ListNode *p=head >next;//从开始结点比较 表非空 p初始值指向开始结点
while(p&&p >data!=key)//直到p为NULL或p >data为key为止
p=p >next;//扫描下一结点
return p;//若p=NULL 则查找失败 否则p指向值为key的结点
③算法分析
cha138/Article/program/sjjg/201311/23307相关参考
插入运算 ()思想方法 插入运算是将值为x的新结点插入到表的第i个结点的位置上即插入到ai与ai之间 具体步骤 ()找到ai存储位置p ()生成一个数据域为x的新结点*s ()令结点*
()尾插法建带头结点的单链表 ①头结点及作用 头结点是在链表的开始结点之前附加一个结点它具有两个优点: ⒈由于开始结点的位置被存放在头结点的指针域中所以在链表的第一个位置上的操作就和在表的其
()尾插法建表 ①算法思路 从一个空表开始重复读入数据生成新结点将读入数据存放在新结点的数据域中然后将新结点插入到当前链表的表尾上直到读入结束标志为止 > 具体方法【参见动画演示】 注意
单链表 链接存储方法 链接方式存储的线性表简称为链表(LinkedList) 链表的具体存储表示为 ①用一组任意的存储单元来存放线性表的结点(这组存储单元既可以是连续的也可以是不连续的)
作为线性表的一种存储结构我们关心的是结点间的逻辑结构(线性关系)而对每个结点的实际地址并不关心所以通常的单链表用图的形式表示 > >
顺序表的存贮特点是利用物理上的相邻关系表达出逻辑上的前驱和后继关系它要求用连续的存储单元顺序存储线性表中各元素因此对顺序表进行插入和删除时需要通过移动数据元素来实现线性表的逻辑上的相邻关系从而影响
> cha138/Article/program/sjjg/201311/23374
链表的每个元素构成一个结点结点定义如下 Typedefstructnode DataTypedata;/*每个元素数据信息*/ structnode*next;/*存放后继元素的地址*/
第一部分线性存储结构 复习策略线性表部分由于比较简单又是整个数据结构的基础所以考察的内容会比较细致对于线性表灵活运用的程度要求较高复习时应充分理解线性表的顺序存储链式存储(单链表静态链表循环链表双向
循环链表(CircularLinkedList) 循环链表是一种首尾相接的链表 循环链表 ()单循环链表——在单链表中将终端结点的指针域NULL改为指向表头结点或开始结点即可 ()多重链的