数据结构复习资料
数据结构复习资料(亲自整理)
数据结构复习资料(亲自整理)1、链表是一种存储数据的链式结构,每个数据之间都是相关联的。
2、线性结构是一个有序数据元素的集合,包括线性表、栈、队列、双队列、数组和串。
3、树是由n(n>=1)个有限节点组成一个具有层次关系的集合,而二叉树是每个结点最多有两个子树的有序树。
二叉树与树的主要差别在于,二叉树结点的最大度数为2,而树中结点的最大度数没有限制;二叉树的结点有左、右之分,而树的结点无左、右之分。
4、堆是一种可以被看做一棵树的数组对象,总是满足某个节点的值总是不大于或不小于其父节点的值,且堆总是一棵完全二叉树。
5、二叉排序树是一种满足以下递归定义的二叉树:若左子树非空,则左子树所有节点的值均小于它的根节点;若右子树非空,则右子树所有节点的值均大于于它的根节点;左右子树也分别为二叉排序树。
1、在已知前序遍历和中序遍历的情况下,可以通过画树的方法求得后序遍历。
具体步骤如下:首先根据前序遍历的特点,确定根节点;然后观察中序遍历,将左子树和右子树分别确定下来;接着对左子树和右子树分别进行递归,直到遍历完所有节点,最后得到后序遍历。
2、树和二叉树之间可以相互转换。
将树转换为二叉树的方法是:对于每个节点,将其第一个孩子作为其左孩子,将其兄弟作为其右孩子。
将二叉树转换为树的方法是:对于每个节点,将其右孩子作为其兄弟。
3、二叉树线索化是将二叉树中的空指针指向该节点在中序遍历中的前驱或后继节点的过程。
在线索二叉树中,一个结点是叶结点的充要条件为:左、右标志均是1.4、邻接表是图的一种链式存储结构,用于表示图中每个节点的邻居节点。
每个节点都有一个链表,存储着与该节点相邻的节点。
邻接表是一种图的存储结构,对于每个顶点建立一个单链表,单链表中的结点表示依附于该顶点的边(对于有向图是以该顶点为尾的弧)。
邻接表中的表结点和头结点分别表示边和顶点,包含信息如下:表结点adjvex(邻接点)。
nextarc(指向下一个表结点)(权值等信息);头结点data(顶点信息)和firstarc(指向第一个表结点)。
数据结构笔试复习
数据结构笔试复习⼀选择题1.下述哪⼀条是顺序存储结构的优点?()A.存储密度⼤ B.插⼊运算⽅便 C.删除运算⽅便 D.可⽅便地⽤于各种逻辑结构的存储表⽰2.数据结构在计算机内存中的表⽰是指( )。
A. 数据的物理结构B. 数据结构C. 数据的逻辑结构D. 数据元素之间的关系3.下⾯关于线性表的叙述中,错误的是哪⼀个?()A.线性表采⽤顺序存储,必须占⽤⼀⽚连续的存储单元。
B.线性表采⽤顺序存储,便于进⾏插⼊和删除操作。
C.线性表采⽤链接存储,不必占⽤⼀⽚连续的存储单元。
D.线性表采⽤链接存储,便于插⼊和删除操作。
4.若线性表最常⽤的操作是存取第i个元素及其前驱的值,则采⽤( )存储⽅式节省时间。
A. 单链表B. 双向链表C. 循环链表D. 顺序表5.线性表是具有n 个()的有限序列(n>0)。
A.表元素 B.字符 C.数据元素 D.数据项 E.信息项6.若某线性表最常⽤的操作是存取任⼀指定序号的元素和在最后进⾏插⼊和删除运算,则利⽤()存储⽅式最节省时间。
A.顺序表 B.双链表 C.带头结点的双循环链表 D.单循环链表7.某线性表中最常⽤的操作是在最后⼀个元素之后插⼊⼀个元素和删除第⼀个元素,则采⽤()存储⽅式最节省运算时间。
A.单链表 B.仅有头指针的单循环链表 C.双链表 D.仅有尾指针的单循环链表8.设⼀个链表最常⽤的操作是在末尾插⼊结点和删除尾结点,则选⽤( )最节省时间。
A. 单链表B.单循环链表C. 带尾指针的单循环链表D.带头结点的双循环链表9.若某表最常⽤的操作是在最后⼀个结点之后插⼊⼀个结点或删除最后⼀个结点。
则采⽤()存储⽅式最节省运算时间。
A.单链表 B.双链表 C.单循环链表 D.带头结点的双循环链表10. 链表不具有的特点是()A.插⼊、删除不需要移动元素 B.可随机访问任⼀元素C.不必事先估计存储空间 D.所需空间与线性长度成正⽐11、3个结点可构成_____棵不同形态的⼆叉树。
数据结构期末考试复习题资料
数据结构期末考试复习题资料一.单项选择题1.算法指的是()。
A.计算方法B.排序方法C.特定问题求解步骤的描述D.调度方法2.下列数据结构中,()是非线性结构。
A.栈B.队列C.完全二叉树D.堆3.若某线性表最常用的操作是存取任一指定序号的元素和在最后进行插入和删除运算,则利用()存储方式最节省时间。
A.顺序表B.双向链表C.单循环链表D.带头结点的双循环链表4.队列的操作原则是()A.先进先出B.后进先出C.先进后出D.不分顺序5.栈和队列的共同特点是()。
A.都是先进先出B.都是先进后出C.都是只允许在端点处插入和删除D.没有共同点6.在一棵高度为k 的满二叉树中,结点总数为()。
A.2k-1 B.2k C.2k-1 D.⎣log 2 k ⎦+ 17.在下列存储形式中,哪一个不是树的存储形式?()A.双亲链表表示法B.孩子链表表示法C.孩子兄弟链表表示法D.顺序存储表示法8.n 个结点的完全有向图含有边的数目为()。
A.n*n B.n*(n+1) C.n/2 D.n*(n-1)9.n 个顶点的强连通图至少有()条边。
A.n B.n-1 C.n+1 D.n(n-1)10、高度为k 的二叉树的最大结点数为()。
A、2kB、2k-1C、2k–1D、2k-1–111、下列哪一种图的邻接矩阵是对称矩阵?()A、有向图B、无向图C、AOV 网D、AOE 网12、在下列存储形式中,哪一个不是树的存储形式?()A、双亲表示法B、孩子表示法C、孩子兄弟表示法D、顺序存储表示法13、下面哪一方法可以判断出一个有向图是否有环。
()A、深度优先遍历B、拓扑排序C、求最短路径D、广度优先遍历14.适用于折半查找的表的存储方式及元素排列要求为()。
A.链接方式存储,元素无序B.链接方式存储,元素有序C.顺序方式存储,元素无序D.顺序方式存储,元素有序15、一个算法应该是()。
A、程序B、特定问题求解步骤的描述C、要满足五个基本特性D、A 和C16、算法分析的两个主要方面是()。
数据结构复习
地址计算 以三对角矩阵为例
三对角矩阵中所有非零元素为3*n-2,可用一维数组s[3*n-2]存储.aij与s[k]
LOC(i,j)=LOC(0,0)+[3*i-1+(j-i+1)]*d
=LOC(0,0)+(2i+j)*d
4.3.2 稀疏矩阵
5、设长度为n的链队列用单循环链表表示,若只设头指针,则怎样进行入队和出队操作;若只设尾指针呢?
6、假设循环队列只设rear和quelen来分别指示队尾元素的位置和队中元素的个数,试给出判断此循环队列的队满条件,并写出相应的入队和出队算法,要求出队时需返回队头指针。
第四章 数组
4.1 数组的定义
(2)能否得到出栈序列423和432?并说明为什么不能得到或如何得到。
(3)请分析1、2、3、4的24种排列中,哪些序列可以通过相应的入出栈得到。
2、表达式求值
3、两个栈共享存储空间r[m],写出向第i个栈插入x,删除第i个栈的栈顶元素算法。
4、循环队列的优点是什么?如何判断它的空和满?循环队列的操作算法?
(2)二叉链表法
5.3 遍历二叉树
在二叉树的一些应用中,常常要求在树中查找具有某
种特征的结点,或者对树中全部结点逐一进行某种处
理。这就引入了遍历二叉树的问题,即如何按某条搜
索路径巡访树中的每一个结点,使得每一个结点均被
访问一次,而且仅被访问一次。
DLR——先(根)序遍历,
LDR——中(根)序遍历,
习题:6.2,6.3,6.5,6.6,6.7,6.12,6.13,6.14,6.19,6.21,6.26,6.42,6.43,6.47,
第六章 图
数据结构复习材料
一、单选题(共20题,40分)1、向一个有127个元素的顺序表中插入一个新元素并保持原来顺序不变,平均要移动的元素个数为()。
(2.0)A、 8B、 63.5C、 63D、 7正确答案: B2、在一个具有n个结点的有序单链表中插入一个新结点并保持该表有序的时间复杂度是()。
(2.0)A、 O(1)B、 O(n)C、O(n²)D、 O(log₂n)正确答案: B3、根据一组关键字(56, 42, 50, 64, 48)依次插入结点生成一棵AVL树,当插入到值为0的结点时需要进行旋转调整。
(2.0)A、 42B、 50C、 64D、 48正确答案: B4、若查找每个元素的概率相等,则在长度为n的顺序表上查找任一元素的平均查找长度为( )。
(2.0)A、 nB、 n+1C、 (n-1)/2D、 (n+1)/2正确答案: D5、在一个长度为n的顺序表中删除第i个元素(0<=i<=n)时,需向前移动个元素。
(2.0)A、 n-iB、 n-i+lC、 n-i-1D、 i正确答案: A6、稀疏矩阵一般的压缩存储方法有两种,即()。
(2.0)A、二维数组和三维数组B、三元组和散列C、三元组和十字链表D、散列和十字链表正确答案: C7、以下关于线性表的说法不正确的是______。
(2.0)A、线性表中的数据元素可以是数字、字符、记录等不同类型。
B、线性表中包含的数据元素个数不是任意的。
C、线性表中的每个结点都有且只有一个直接前趋和直接后继。
D、存在这样的线性表:表中各结点都没有直接前趋和直接后继。
正确答案: C8、在n个结点的顺序表中,算法的时间复杂度是O(1)的操作是()。
(2.0)A、访问第i个结点(1≤i≤n)和求第i个结点的直接前驱(2≤i≤n)B、在第i个结点后插入一个新结点(1≤i≤n)C、删除第i个结点(1≤i≤n)D、将n个结点从小到大排序正确答案: A9、一棵非空的二叉树的先序遍历序列与后序遍历序列正好相同,则该二叉树一定满足()。
数据结构复习要点
A—熟练掌握B—理解C—了解第一章:绪论1. 基本概念:包括数据的逻辑结构、数据的存储结构和数据的相关运算。
C四类数据组织结构:集合、线性表、树形、图状结构C数据的存储方式:顺序存储和链式存储。
B2.算法和分析算法的特征、时间复杂度的分析和常见的时间复杂度增长率排序、空间复杂度B本章重点:分析算法时间复杂度例1. 下面关于算法说法错误的是()A.算法最终必须由计算机程序实现B.为解决某问题的算法同为该问题编写的程序含义是相同的C. 算法的可行性是指指令不能有二义性D. 以上几个都是错误的D例2. 以下那一个术语与数据的存储结构无关?()A.栈 B. 哈希表 C. 线索树 D. 双向链表A.例3..求下段程序的时间复杂度:void mergesort(int i, int j){int m;if(i!=j){m=(i+j)/2;mergesort(i,m);mergesort(m+1,j);merge(i,j,m);}}其中mergesort()用于对数组a[n]归并排序,调用方式为mergesort(0,n-1);,merge()用于两个有序子序列的合并,是非递归函数,时间复杂度为。
解:分析得到的时间复杂度的递归关系:为merge()所需的时间,设为cn(c为常量)。
因此令,有有第二章:线性表1.线性表的基本运算:….. C2.线性表的顺序存储(利用静态数组或动态内存分配)。
相应的表示与操作 A3.线性表的链式存储。
相应的表示与操作。
包括循环链表、双向链表。
A4.顺序存储与链式存储的比较:基于时间的考虑--分别适用于静态的和动态的操作:比如静态查找和插入删除);基于空间的考虑-- ……. B这也适用于后面用两种方式存储的其他数据结构。
★本章重点:很熟悉顺序表,单链表、双链表,循环链表的基本操作;并学会在各种链表上进行一些算法设计(与基本操作类似的操作或组合),请仔细复习。
例4.假设有两个按元素值递增次序排列的线性表,均以单链表形式存储。
《数据结构》复习资料
《数据结构》复习资料《数据结构》复习资料1⼀、选择题1. ⼀棵⼆叉树中第6层上最多有()个结点。
A. 2B. 31C. 32D. 642. 顺序表中数据元素的存取⽅式为()。
A. 随机存取B. 顺序存取C. 索引存取D. 连续存取3. 设有⽆向图G=(V,E),其中顶点集合V={a,b,c,d,e,f},边集合E={(a,b), (a,e), (a,c), (b,e), (c,f), (f,d), (e,d)}。
对G进⾏深度优先遍历,正确的遍历序列是()。
A. a,b,e,c,d,fB. a,c,f,e,b,dC. a,e,b,c,f,dD. a,e,d,f,c,b4. 在待排元素序列基本有序的前提下,效率最⾼的排序⽅法是()。
A. 插⼊B. 选择C. 快速D. 归并5. 设表中含100个数据元素,⽤折半查找法进⾏查找,则所需最⼤⽐较次数为()。
A. 50B. 25C. 10D. 76. 设哈希表地址范围为0~19,哈希函数H(key)=key%17,使⽤⼆次探测再散列法处理冲突。
若表中已存放有关键字值为6、22、38、55的记录,则再放⼊关键字值为72的记录时,其存放地址应为()。
A. 2B. 3C. 4E. 8F. 以上都不对7. 设对下图从顶点a出发进⾏深度优先遍历,则()是可能得到的遍历序列。
A. acfgdebB. abcdefgC. acdgbefD. abefgcd8. 若需在O(nlog2n)的时间内完成对数组的排序,且要求排序是稳定的,则可选择的排序⽅法是()。
A. 快速排序B. 堆排序C. 归并排序D. 直接插⼊排序9. 设有⼀组关键字值(46,79,56,38,40,84),则⽤堆排序的⽅法建⽴的初始堆为()。
A. 79,46,56,38,40,84B. 84,79,56,38,40,46C. 84,79,56,46,40,38D. 84,56,79,40,46,3810. 设⼴义表L=((a,()),b,(c,d,e)),则Head(Tail(Tail(L)))的值为()。
数据结构总复习资料(完整版)
2018数据结构总复习第一章概论1.1数据结构的定义和分类1.数据结构的定义数据结构是一门研究非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和操作的学科。
2.数据结构包括的内容(1)逻辑结构:数据元素之间的逻辑关系。
(2)存储结构:数据元素及其关系在计算机存储器内的表示。
(3)操作:数据的运算(检索、排序、插入、删除、修改)。
1.2为什么学习数据结构1.学习数据结构的作用(1)计算机内的数值运算依靠方程式,而非数值运算(如表、树、图等)则要依靠数据结构。
(2)同样的数据对象,用不同的数据结构来表示,运算效率可能有明显的差异。
(3)程序设计的实质是对实际问题选择一个好的数据结构,加之设计一个好的算法。
而好的算法在很大程度上取决于描述实际问题的数据结构。
2.电话号码查询问题(1)要写出好的查找算法,取决于这张表的结构及存储方式。
(2)电话号码表的结构和存储方式决定了查找(算法)的效率。
1.3算法的概念和特点1.算法的概念和特点算法是由若干条指令组成的有穷序列,具有以下特点:(1)输入:具有0个或多个输入的外界量。
(2)输出:至少产生1个输出。
(3)有穷性:每一条指令的执行次数必须是有限的。
(4)确定性:每条指令的含义都必须明确,无二义性。
(5)可行性:每条指令的执行时间都是有限的。
2.算法与程序的区别(1)一个程序不一定满足有穷性,但算法一定。
(2)程序中的指令必须是机器可执行的,而算法无此限制。
(3)一个算法若用机器可执行的语言来描述,则它就是一个程序。
1.4算法分析1.时间复杂度算法中基本操作重复执行的次数是问题规模n的某个函数,用T(n)表示,若有某个辅助函数f(n),使得当n趋近于无穷大时,T(n) / f(n) 的极限值为不等于零的常数,则称f(n)是T(n)的同数量级函数。
记作T(n)=O(f(n)),称O(f(n)) 为算法的渐近时间复杂度,简称时间复杂度。
算法效率的度量,采用时间复杂度。
数据结构(C语言版)知识点复习资料
数据结构复习资料一、填空题1. 数据结构是一门研究非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和运算等的学科。
2. 数据结构被形式地定义为(D, R),其中D是数据元素的有限集合,R是D上的关系有限集合。
3. 数据结构包括数据的逻辑结构、数据的存储结构和数据的运算这三个方面的内容。
4. 数据结构按逻辑结构可分为两大类,它们分别是线性结构和非线性结构。
5. 线性结构中元素之间存在一对一关系,树形结构中元素之间存在一对多关系,图形结构中元素之间存在多对多关系。
6.在线性结构中,第一个结点没有前驱结点,其余每个结点有且只有 1个前驱结点;最后一个结点没有后续结点,其余每个结点有且只有1个后续结点。
7. 在树形结构中,树根结点没有前驱结点,其余每个结点有且只有 1 个前驱结点;叶子结点没有后续结点,其余每个结点的后续结点数可以任意多个。
8. 在图形结构中,每个结点的前驱结点数和后续结点数可以任意多个。
9.数据的存储结构可用四种基本的存储方法表示,它们分别是顺序、链式、索引和散列。
10. 数据的运算最常用的有5种,它们分别是插入、删除、修改、查找、排序。
11. 一个算法的效率可分为时间效率和空间效率。
12. 在顺序表中插入或删除一个元素,需要平均移动表中一半元素,具体移动的元素个数与表长和该元素在表中的位置有关。
13. 线性表中结点的集合是有限的,结点间的关系是一对一的。
14. 向一个长度为n的向量的第i个元素(1≤i≤n+1)之前插入一个元素时,需向后移动 n-i+1 个元素。
15. 向一个长度为n的向量中删除第i个元素(1≤i≤n)时,需向前移动 n-i 个元素。
16. 在顺序表中访问任意一结点的时间复杂度均为 O(1) ,因此,顺序表也称为随机存取的数据结构。
17. 顺序表中逻辑上相邻的元素的物理位置必定相邻。
单链表中逻辑上相邻的元素的物理位置不一定相邻。
18.在单链表中,除了首元结点外,任一结点的存储位置由其直接前驱结点的链域的值指示。
数据结构复习资料 第4章
第4章栈和队列一、复习要点本章主要讨论3种线性结构:栈、队列与优先级队列。
这3种结构都是顺序存取的表,而且都是限制存取点的表。
栈限定只能在表的一端(栈顶)插入与删除,其特点是先进后出。
队列和优先级队列限定只能在表的一端(队尾)插入在另一端(队头)删除,不过优先级队列在插入和删除时需要根据数据对象的优先级做适当的调整,令优先级最高的对象调整到队头,其特点是优先级高的先出。
而队列不调整,其特点是先进先出。
这几种结构在开发各种软件时非常有用。
本章复习的要点:1、基本知识点要求理解栈的定义和特点,栈的抽象数据类型和在递归和表达式计算中的使用,在栈式铁路调车线上当进栈序列为1, 2, 3, , n时,可能的出栈序列计数,栈的顺序存储表示和链接存储表示,特别要注意,链式栈的栈顶应在链头,插入与删除都在链头进行。
另外,需要理解队列的定义和特点,队列的抽象数据类型和在分层处理中的使用,队列的顺序存储表示(循环队列)和链接存储表示,需要注意的是,链式队列的队头应在链头,队尾应在链尾。
还需要理解优先级队列的定义和特点。
优先级队列的最佳存储表示是堆(heap),本章介绍的表示看懂即可。
2、算法设计➢栈的5种操作(进栈、退栈、取栈顶元素、判栈空、置空栈)的在顺序存储表示下的实现,以及在链接存储表示下的实现。
➢使用栈的后缀表达式计算算法➢循环队列的进队列、出队列、取队头元素、判队列空、置空队列操作的实现➢链式队列的进队列、出队列、取队头元素、判队列空、置空队列操作的实现二、难点和重点1、栈:栈的特性、栈的基本运算➢栈的数组实现、栈的链表实现➢栈满及栈空条件、抽象数据类型中的先决条件与后置条件2、栈的应用:用后缀表示计算表达式,中缀表示改后缀表示3、队列:队列的特性、队列的基本运算➢队列的数组实现:循环队列中队头与队尾指针的表示,队满及队空条件➢队列的链表实现:链式队列中的队头与队尾指针的表示、三、习题的解析4-2 铁路进行列车调度时, 常把站台设计成栈式结构的站台,如右图所示。
数据结构复习
一、填空:1.顺序存储结构的特点是(),链接存储结构的特点是()。
【解答】用元素在存储器中的相对位置来表示数据元素之间的逻辑关系,用指示元素存储地址的指针表示数据元素之间的逻辑关系。
2.算法在发生非法操作时可以作出处理的特性称为(健壮性)。
【解答】健壮性3.常见的算法时间复杂度用大O记号表示为:常数阶(O(1) )、对数阶(O(log2n) )、线性阶(O (n))、平方阶(O(n2) )和指数阶(O(2n))。
【解答】O(1),O(log2n),O(n),O(n2),O(2n)4.将下列函数按它们在n 时的无穷大阶数,从小到大排列。
n, n-n3+7n5, nlogn, 2n/2, n3, log2n, n1/2+log2n, (3/2)n, n!, n2+log2n【解答】log2n, n1/2+log2n, n, nlog2n, n2+log2n, n3, n-n3+7n5, 2n/2, (3/2)n, n!5.在长度为n的线性表中查找值为x的数据元素的时间复杂度为:(c )。
A O(0) B O(1) C O(n) D O(n2)【解答】C6.在一个长度为n的顺序表的第i(1≤i≤n+1)个元素之前插入一个元素,需向后移动(n-i+1 )个元素,删除第i(1≤i≤n)个元素时,需向前移动(n-i )个元素。
【解答】n-i+1,n-i7.在单链表中,除了头结点以外,任一结点的存储位置由(其前趋结点的指针域)指示。
【解答】其前趋结点的指针域8.当线性表采用顺序存储结构时,其主要特点是(逻辑结构中相邻的结点在存储结构中仍相邻)。
【解答】逻辑结构中相邻的结点在存储结构中仍相邻9 栈通常采用的两种存储结构是(顺序存储结构和链接存储结构);其判定栈空的条件分别是(栈顶指针top=-1和top=NULL),判定栈满的条件分别是(栈顶指针top等于数组的长度和内存无可用空间)。
【解答】顺序存储结构和链接存储结构(或顺序栈和链栈),栈顶指针top= -1和top=NULL,栈顶指针top等于数组的长度和内存无可用空间10(栈)可作为实现递归函数调用的一种数据结构。
数据结构复习资料复习提纲知识要点归纳
第一章数据结构概述基本概念与术语1.数据:数据是用来描述现实世界的文字,字符,图像,声音,以及能够输入到计算机中并能被计算机处理的符号。
2.数据元素:数据元素是数据的基本单位,是数据这个集合中的个体,也称之为元素,结点,顶点记录。
(补充:一个数据元素可由若干个数据项组成。
数据项是数据的不可分割的最小单位。
)3.数据对象:数据对象是具有相同性质的数据元素的集合,是数据的一个子集。
(有时候也叫做属性。
)4.数据结构:数据结构是相互之间存在一种或多种特定关系的数据元素的集合。
(1)数据的逻辑结构:数据的逻辑结构是指数据元素之间存在的固有逻辑关系,常称为数据结构。
数据的逻辑结构是从数据元素之间存在的逻辑关系上描述数据与数据的存储无关,是独立于计算机的。
依据数据元素之间的关系,可以把数据的逻辑结构分成以下几种:a.集合:数据中的数据元素之间除了“同属于一个集合“的关系以外,没有其他关系。
b.线性结构:结构中的数据元素之间存在“一对一“的关系。
若结构为非空集合,则除了第一个元素之外,和最后一个元素之外,其他每个元素都只有一个直接前驱和一个直接后继。
c.树形结构:结构中的数据元素之间存在“一对多“的关系。
若数据为非空集,则除了第一个元素(根)之外,其它每个数据元素都只有一个直接前驱,以及多个或零个直接后继。
d.图状结构:结构中的数据元素存在“多对多”的关系。
若结构为非空集,折每个数据可有多个(或零个)直接后继。
(2)数据的存储结构:数据元素及其关系在计算机内的表示称为数据的存储结构。
想要计算机处理数据,就必须把数据的逻辑结构映射为数据的存储结构。
逻辑结构可以映射为以下两种存储结构:a.顺序存储结构:把逻辑上相邻的数据元素存储在物理位置也相邻的存储单元中,借助元素在存储器中的相对位置来表示数据之间的逻辑关系。
b.链式存储结构:借助指针表达数据元素之间的逻辑关系。
不要求逻辑上相邻的数据元素物理位置上也相邻。
5.时间复杂度分析:a.常量阶:算法的时间复杂度与问题规模n无关系T(n)=O(1)b.线性阶:算法的时间复杂度与问题规模n成线性关系T(n)=O(n)c.平方阶和立方阶:一般为循环的嵌套,循环体最后条件为i++时间复杂度的大小比较:O(1)< O(log 2 n)< O(n )< O(n log 2 n)< O(n2)< O(n3)< O(2 n )<O(n!)<O(n n)6.算法与程序:(1)算法的5个特性a、输入:有零个或多个输入b、输出:有一个或多个输出c、有穷性:要求序列中的指令是有限的;每条指令的执行包含有限的工作量;整个指令序列的执行在有限的时间内结束。
数据结构期末复习资料
数据结构期末复习资料数据结构期末复习材料第一章1、数据结构是一门研究非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和操作等的学科。
数据结构(Data Structure):相互之间存在一种或多种特定关系的数据元素的集合。
2、数据结构的形式定义:二元组Data_Structure=(D,S) 其中,D 是数据元素的有限集,S 是D 上关系的有限集。
3、数据元素之间关系的映像:1、顺序映像(顺序存储结构):以相对的存储位置表示后继关系。
2、非顺序映像(链式存储结构):借助指针元素存储地址的指针表示数据元素之间的逻辑关系。
任何一个算法的设计取决于数据(逻辑)结构,其实现取决于物理结构。
4、算法的定义:对特定问题求解步骤的一种描述,它是指令的有限序列,其中每一条指令表示一个或多个操作。
特性:有穷性、确定性、可行性、输入、输出5、算法的评价——衡量算法优劣的标准正确性(correctness):满足具体问题的需求可读性(readability):易读、易理解健壮性(robustness):当输入数据非法时,算法能够做出反应或进行处理效率与低存储量:执行时间短、存储空间小第二章1、线性表是一种最简单的线性结构。
线性结构是一个数据元素的有序(次序)关系特点:存在唯一的一个―第一个‖的数据元素;存在唯一的一个―最后一个‖的数据元素;除第一个数据元素外,均有唯一的前驱;除最后一个数据元素外,均有唯一的后继2、线性表类型的实现——顺序映像定义:用一组地址连续的存储单元依次存放线性表中的数据元素。
以―存储位置相邻‖表示有序对,则有:LOC (ai ) = LOC (ai -1) + l 其中l 是一个数据元素所占存储量LOC (ai ) = LOC (a 1) + (i -1)×l特点:1、实现逻辑上相邻—物理地址相邻2、实现随机存取3、若假定在线性表中任何一个位置上进行插入的概率都是相等的,则移动元素的期望值为:∑+=+-+=11)1(11n i is i n n E2n = 若假定在线性表中任何一个位置上进行删除的概率都是相等的,则移动元素的期望值为:∑=-=ni dl i n n E 1)(121-=n 4、线性表类型的实现——链式映像线性链表特点:用一组地址任意的存储单元存放线性表中的数据元素。
数据结构期末复习资料
数据结构复习资料第一章绪论1.1基本概念和术语1.数据是对客观事物的符号表示;数据元素是数据的基本单位,一个数据元素可由若干个数据项组成,数据项是数据的不可分割的最小单位;数据对象是性质相同的数据元素的集合,是数据的一个子集。
2.数据结构是相互之间存在一种或多种特定关系的数据元素的集合。
3.A.数据结构的三要素:①数据的逻辑结构②数据的存储结构③数据的运算(算法)B.任何一个算法的设计取决于选定的逻辑结构,而算法的实现依赖于采用的存储结构4.数据的逻辑结构:①集合②线性结构③树型结构④图状结构或网状结构1.2算法和算法分析1.算法的五个特性:①有穷性②确定性③可行性④输入⑤输出2.时间复杂度:时间复杂度是指执行算法所需要的计算工作量空间复杂度:空间复杂度是指执行这个算法所需要的内存空间第二章线性表2.1线性表的顺序表示和实现1.线性表的顺序表示指的是用一组地址连续的存储单元依次存储线性表的数据元素。
2.优点:线性表的顺序存储结构是一种随机存取的存储结构3.顺序线性表插入:顺序线性表删除:4.线性表的链式存储结构的特点是用一组任意的存储单元存储线性表的数据元素(可连续,可不连续)5.对数据元素来说,除了存储其自身的信息之外,还需存储一个指示其直接后继的信息(存储位置),这两部分信息组成数据元素的存储映像,称为结点。
他包括两个域:其中存储数据元素信息的域称为数据域;存储直接后继存储位置的域称为指针域。
指针域中存储的信息称为指针或域。
N个结点链结成一个链表,即为线性表的链式存储结构。
又由于此链表的每个结点中只包含一个指针域,故又称为线性链表或单链表。
6.链表的插入与删除7.双向链表的插入与删除第三章栈和队列3.1 栈1.栈是限定仅在表尾进行插入或删除操作的线性表。
因此,对栈来说,表尾端有其特殊含义,称为栈顶,相应的,表头端称为栈底。
不含元素的空表称为空栈。
2.栈又称为后进先出的线性表3.栈的进栈与出栈操作3.2队列1.队列是一种先进先出的线性表,它只允许在表的一段进行插入,而在另一端删除元素。
数据结构复习内容
《数据结构》复习内容一.单选题1.链栈与顺序栈相比,有一个比较明显的优点是BA.插入操作更加方便B.通常不会出现栈满的情况C.不会出现栈空的情况D.删除操作更加方便2.从未排序序列中挑选元素,将其放在已排序序列的一端,这种排序方法称为AA.选择排序B.插入排序C.快速排序D.冒泡排序3.若n个顶点的无向图采用邻接矩阵存储方法,该邻接矩阵是一个BA.一般矩阵B.对称矩阵C.对角矩阵D.稀疏矩阵4.一个n*n的对称矩阵,如果以行或列为主序放入内存,则其容量为CA.n*nB.n*n/2C.(n+1)*n/2D.(n+1)*(n+1)/25.当栈中的元素为n个,作进栈运算时发生上溢,则说明该栈的最大容量为BA.n-1B.nC.n+1D.n/26.在单链表中,增加头结点的目的是CA.使单链表至少有一结点B.标志表中首结点位置C.方便运算的实现D.说明单链表是线性表的链式存储实现8.在一个图中,所有顶点的度数之和等于所有边数的倍。
CA.1/2B.1C.2D.47.下列排序方法中,排序趟数与序列的原始状态有关的方法是DA.选择排序B.希尔排序C.堆排序D.冒泡排序8.在一棵具有五层的满二叉数中,结点总数为AA.31B.32C.33D.169.线性表是AA.一个有限序列,可以为空B.一个有限序列,不能为空C.一个无限序列,可以为空D.一个无限序列,不能为空12.下列排序算法中,排序在每趟结束后不一定能选出一个元素放到其排好序的最终位置上。
CA.选择B.冒泡C.归并D.堆13.二维数组a的每个元素是由6个字符组成的串,行下标的范围从0到8,列下标的范围从1到10,则存放a至少需要个字节。
DA.90B.180C.270D.54014.对有14个元素的有序表A[1..14]作二分查找,查找元素A[4]时的被比较元素依次为CA.A[1],A[2],A[3],A[4]B.A[1],A[14],A[7],A[4]C.A[7],A[3],A[5],A[4]D.A[7],A[5],A[3],A[4]15.以二叉链表作为二叉树的存储结构,在具有n个结点的二叉链表中(n>0 ),空链域的个数为CA.2n-1B.n-1C.n+1D.2n+116.向顺序栈中压入元素时AA.先移动栈顶指针,后存人元素B.先存人元素,后移动后移动栈顶指针C.谁先谁后无关紧要D.同时进行17.下列存储形式中,哪一个不是树的存储形式DA.双亲表示法B.孩子链表表示法C.孩子兄弟表示法D.顺序存储表示法18.对n个记录的文件进行堆排序,最坏情况下的执行时间为A.O(log2n)B.O(n)C.O(nlog2n)D.O(n2)19用链表表示线性表的优点是CA.便于随机存取B.花费的存储空间比顺序表少C.便于插入和删除D.数据元素的物理顺序与逻辑顺序相同20.下列有关线性表的叙述中,正确的是AA.线性表中的元素之间是线性关系B.线性表中至少有一个元素C.线性表中任何一个元素有且仅有一个直接前驱D.线性表中任何一个元素有且仅有一个直接后继21.线性表的顺序存储结构中,一般情况下,在第i(1≤i≤n)个元素之前插入一个元素时,需向后移动()个元素。
数据结构复习资料
数据结构复习资料一、单项选择题:1、以下说法正确的是(B )。
A.数据元素是数据的最小单位B.数据项是数据的基本单位C.数据结构是带有结构的各数据项的集合D.一些表面上很不相同的数据可以有相同的逻辑结构2、在数据结构中,从逻辑上可以把数据结构分成(C )。
A.动态结构和静态结构B.紧凑结构和非紧凑结构C.线性结构和非线性结构D.以上三个选项都是不是3、以下数据结构中,(A )是非线性数据结构A.树B.字符串C.队D.栈4. 对于int *pa[5]的描述,( D )是正确的。
A.pa是一个指向数组的指针,所指向的数组是5个int型元素B.pa是一个指向某数组中的第5个元素的指针,该元素是int型变量C.pa[5]表示某个数组的第5个元素的值D.pa是一个具有5个元素的指针数组,每个元素是一个int型指针5、在int a[][3]={{1},{3,2},{4,5,6},{0}}中,a[2][2]的值是( C )。
A.3B. 2C.6D.41. 栈和队列的共同特点是( A )。
A.只允许在端点处插入和删除元素B.都是先进后出C.都是先进先出D.没有共同点2. 用链接方式存储的队列,在进行插入运算时( D ).A. 仅修改头指针B. 头、尾指针都要修改C. 仅修改尾指针D.头、尾指针可能都要修改3. 算法分析的目的是:( C )A.找出数据结构的合理性 B.研究算法中的输入和输出的关系C.分析算法的效率以求改进D.分析算法的易懂性和文档性4. 算法分析的两个主要方面是:( A )A.空间复杂性和时间复杂性B.正确性和简明性C.可读性和文档性D.数据复杂性和程序复杂性5. 计算机算法指的是:( C )A.计算方法B.排序方法C.解决问题的有限运算序列D.调度方法6.循环链表的主要优点是( B ) 。
A.不在需要头指针了B.已知某个结点的位置后,能够容易找到他的直接前趋C.在进行插入、删除运算时,能更好的保证链表不断开D.从表中的任意结点出发都能扫描到整个链表7.设带有头结点的单向循环链表的头指针变量为head,则其判空条件是( B )。
国家开放大学《数据结构(本)》复习资料
《数据结构》复习资料一、单项选择题1.一种逻辑结构在存储时(C)。
A.只要存储数据元素间的关系B.只能采用一种存储结构c.可采用不同的存储结构 D.只要存储数据元素的值2.对链表,以下叙述中正确的是(A)A.不能随机访问任一结点B.结点占用的存储空间是连续的c.插入删除元素的操作一定要移动结点D.可以通过下标对链表进行直接访问3.线性表在存储后,如果相关操作是:要求已知第i个结点的位置访问该结点的前驱结点,则采用(A)存储方式是不可行的。
A.单链表B.双链表 c.单循环链表 D.顺序表4.械和队列的共同特点是(C)。
A.都是先进后出B.元素都可以随机进出c.只容许在端点处插入和删除元素 D.都是先进先出5.元素2,4,6,8按顺序依次进拢,按该校的可能输出序列依次人队列,该队列的可能输出序列是(D)(进找出校可以交替进行)。
A.8,6,2,4B.8,4,2,6C.6,2,4,8D.8,6,4,26.在一个不带头结点的链队中,假设f和r分别为队头和队尾指针,则从该对列中删除一个结点并把结点的值保存在变量x中的运算为(C)。
A.x=r•data;r=r•next;B.r=r•next;x=r•dataC.x=f•data;f=f•next;D.f=f•next;x=f•data7.设有一个20阶的对称矩阵A,采用压缩存储的方式,将其下三角部分以行序为主序存储到一维数组B中(数组下标从1开始),则数组中第38号元素对应于矩阵中的元素是(C)。
(矩阵中的第1个元素是al,l)A.alO,8B.a7,6C.a9,2D.句,58.在C语言中,分别存储"S"和‘s',各需要占用(D)字节。
A.一个和两个B.两个c.一个 D.两个和一个9.一棵有n个结点,采用链式存储的二叉树中,共有()个指针域被有效使用(C)。
A.n+1B.nC.n-1D.n-210.在一棵二叉树中,若编号为i的结点存在双亲结点,则双亲结点的顺序编号为(B)。
数据结构期末复习重点知识点总结
第一章绪论一、数据结构包括:逻辑结构、存储结构、运算(操作)三方面内容。
二、线性结构特点是一对一。
树特点是一对多图特点是多对多三、数据结构的四种存储结构:顺序存储、链式存储、索引存储、散列存储顺序存储结构和链式存储结构的区别?线性结构的顺序存储结构是一种随机存取的存储结构。
线性结构的链式存储是一种顺序存取的存储结构。
逻辑结构分类:集合线性树图,各自的特点。
或者分为线性结构和非线性结构。
四、算法的特征P13五、时间复杂度(1) i=1; k=0;while(i<n){ k=k+10*i;i++;}分析:i=1; //1k=0; //1while(i<n) //n{ k=k+10*i; //n-1i++; //n-1}由以上列出的各语句的频度,可得该程序段的时间消耗:T(n)=1+1+n+(n-1)+(n-1)=3n可表示为T(n)=O(n)六、数据项和数据元素的概念。
第二章线性表一、线性表有两种存储结构:顺序存储和链式存储,各自的优、缺点。
二、线性表的特点。
三、顺序表的插入、思想、时间复杂度o(n)、理解算法中每条语句的含义。
(1)插入的条件:不管是静态实现还是动态实现,插入的过程都是从最后一个元素往后挪动,腾位置。
静态是利用数组实现,动态是利用指针实现。
不管静态还是动态,在表中第i个位置插入,移动次数都是n-i+1。
四、顺序表的删除、思想、时间复杂度o(n)、理解算法中每条语句的含义。
(1)删除的条件:不管是静态实现还是动态实现,删除的过程都是从被删元素的下一位置向前挪动。
静态是利用数组实现,动态是利用指针实现。
不管静态还是动态,删除表中第i个元素,移动次数都是n-i。
五、顺序表的优缺点?为什么要引入链表?答:顺序表的优点是可以随机存取,缺点是前提必须开辟连续的存储空间且在第一位置做插入和删除操作时,数据的移动量特别大。
如果有一个作业是100k,但是内存最大的连续存储空间是99K,那么这个作业就不能采用顺序存储方式,必须采用链式存储方式。
数据结构复习资料
一、填空题1、栈的特点是先进后出(或后进先出),队列的特点是先进先出。
2、顺序表中逻辑上相邻的元素物理位置也相邻,单链表中逻辑上相邻的元素物理位置不相邻。
3、算法的5个重要特性是__________、__________、_________、___________、___________。
4、线性表、栈、队列都是线性结构,可以在线性表的任何位置插入和删除元素,对于栈只能在栈顶位置插入和删除元素,对于队列只能在队尾位置插入和只能在队头删除元素。
5、下面树的先序、中序、后续遍历的结果依次为_________、___________、__________6、当数据量特别大需借助外部存储器对数据进行排序时,则这种排序称为外部排序。
7、在堆排序、快速排序和归并排序中,若从节省存储空间的角度考虑,则应首先选取堆排序方法;若只从排序结果的稳定性考虑,则应选择归并排序方法;若只从平均情况下排序的速度来考虑,则应选取快速排序方法。
二、选择题1、算法分析的两个主要方面是()。
A. 时间复杂度和空间复杂度B. 正确性和简明性C. 可读性和文档性D. 健壮性和科学性2、对于线性表最常用的操作是查找指定序号的元素和在末尾插入元素,则选择()最节省时间。
A. 顺序表B. 带头结点的双循环链表C. 单链表D. 带尾结点的单循环链表5、循环队列在进行删除运算时()A. 仅修改头指针B. 修改尾指针C. 头、尾指针都要修改D. 头、尾指针可能都要修改6、栈和队列的共同点是()。
A.都是先进后出B.都是先进先出C.只允许在端点处插入和删除元素D.没有共同点7、树最适合用来表示()A.有序数据元素 B. 无序数据元素C.元素之间具有分支层次关系的数据 D. 元素之间无联系的数据8、如果结点A有3个兄弟,而且B是A的双亲,则B的度是()A. 4B. 5C. 1D. 39、有关二叉树下列说法正确的是()A. 二叉树的度为2B. 一棵二叉树的度可以小于2C. 二叉树中至少有一个结点的度为2D. 二叉树中任何一个结点的度都为210、一棵完全二叉树上有1001个结点,其中叶子结点的个数是()A. 250B. 500C. 505D. 以上答案都不对11、静态查找表与动态查找表二者的根本差别在于(B)A. 它们的逻辑结构不一样B. 施加在其上的操作不同C. 所包含的数据元素的类型不一样D. 存储实现不一样12、顺序查找法适合于存储结构为(B)的线性表。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第一章绪论1、数据结构就是研究数据的逻辑结构和物理结构以及它们之间相互关系,并对这种结构定义相应的运算,而且确保经过这些运算后所得到的新结构仍然是原来的结构类型。
2、数据(Data):所有能输入到计算机中去的描述客观事物的符号。
3、数据元素(Data Element):是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。
一个数据元素可由若干个数据项组成。
数据项是数据的不可分割的最小单位。
4、数据对象(Data Object):是性质相同的数据元素的集合。
是数据的一个子集。
5、数据结构(Data Structure):简单地说数据元素之间的“关系”即是结构。
数据结构即是数据元素之间相互的关系(简单理解)。
6、一般,数据结构的研究包括三个方面:逻辑结构、物理结构、算法。
7、物理(存储)结构:数据结构在计算机中的存储表示称为数据的存储结构。
它包括数据元素的表示和关系的表示。
8、存储结构分为:顺序存储结构——借助元素在存储器中的相对位置来表示数据元素间的逻辑关系链式存储结构——借助指示元素存储地址的指针表示数据元素间的逻辑关系9、逻辑结构通常分为四大类:集合:数据元素间除“同属于一个集合”外,无其它关系线性结构:一个对一个,如线性表、栈、队列树形结构:一个对多个,如树图状结构:多个对多个,如图10、算法(algorithm):是对特定问题求解步骤的一种描述,算法是指令的有限序列,其中每一条指令表示一个或多个操作。
算法特性:1.有穷性:2.确定性:3.可行性:4.输入:5.输出:11、算法的评价—衡量算法优劣的标准正确性(correctness):a,b,c,d四个层次可读性(readability):方便阅读健壮性(robustness):可容错效率与低存储量算法效率——用依据该算法编制的程序在计算机上执行所消耗的时间来度量。
1.事后统计2.事前分析估算12、时间复杂度(Time complexity):算法中基本操作重复执行的次数是问题规模n的某个函数,将算法的时间量度记作T(n)=O(f(n))称作算法的渐近时间复杂度简称为时间复杂度。
13、空间复杂度(Space complexity):指算法运行从开始到结束所需的存储量。
算法的存储量指的是算法执行过程中所需的最大存储空间。
算法执行期间所需要的存储量应该包括三部分:(1) 输入数据所占空间;(2) 程序本身所占空间;(3) 辅助变量所占空间。
类似于算法的时间复杂度,通常以算法的空间复杂度作为算法所需存储空间的量度,S(n)=O(g(n)) 称S(n)为算法的空间复杂度。
14、六种计算算法时间的多项式是最常用的。
其关系为:O(1)<O(logn)<O(n)<O(nlogn)<O(n2)<O(n3)指数时间的关系为:O(2n)<O(n!)<O(nn)第二章线性表1、线性表(Linear list):是由一组具有相同属性的数据元素构成。
特点:1.存在一个唯一的没有前驱的(头)数据元素;2.存在一个唯一的没有后继的(尾)数据元素;3.此外,每一个数据元素均有一个直接前驱和一个直接后继数据元素。
2、线性表:是由n(n≧0)个具有相同属性的数据元素a1,a2,a3,…,an组成的有限序列,其中序列中元素的个数n称为线性表的长度。
当n=0时称为空表,即不含有任何元素。
常常将非空的线性表(n>0)记作:(a1,a2,…an)3、线性表的逻辑特征是:(a1,a2,…ai-1,ai,ai+1…,an-1,an)在非空的线性表,有且仅有一个开始结点a1,它没有直接前趋,而仅有一个直接后继a2;有且仅有一个终端结点an,它没有直接后继,而仅有一个直接前趋an-1;其余的内部结点ai(2≦i≦n-1)都有且仅有一个直接前趋ai-1和一个直接后继ai+1。
线性表是一种典型的线性结构。
4、线性表的顺序表示:用一组地址连续的存储单元依次存储线性表的数据元素。
假设线性表的每个元素需占用C个存储单元,并以所占的第一个单元的存储地址作为数据元素的存储位置。
则线性表中第i+1个数据元素的存储位置LOC(ai+1)和第i个数据元素的存储位置LOC(ai)之间满足下列关系:LOC(ai+1)=LOC(ai)+C线性表的第i个数据元素ai的存储位置为:LOC(ai)=LOC(a1)+(i-1)×C5、顺序表特点是:用元素在计算机内存中“物理位置相邻”来表示线性表之间的逻辑关系。
顺序表特性:随机存取。
只要确定了线性表的起始位置以及元素在线性表中的逻辑顺序便可计算出元素的地址,所以能够实现随机存取数据。
高级程序设计语言中的数组类型也具有随机存取的特性,因此顺序表常用数组来实现。
6、(1)插入一个元素。
在表的第i(1≦i≦n+1)个位置上,插入一个新结点x,使长度为n的线性表(a1,…ai-1,ai,…,an)变成长度为n+1的线性表(a1,…ai-1,x,ai,…,an)元素ai-1和ai之间的逻辑关系也发生了变化。
算法时间复杂度的分析。
该算法的时间主要花费在移动数据元素上,移动个数取决于插入位置i和表的长度n。
所以可以用数据元素的移动操作来估计算法的时间复杂度。
在第i个位置上插入x ,共需要移动n-i+1个元素,i 的取值范围为:1≤i≤n+1,即有n+1个位置可以插入。
当i=n+1时,不需要移动结点;当i=1时需要移动n个结点。
由此可以看出,算法在最好的情况下时间复杂性为O(1),最坏的时间复杂性是O(n)。
由于插入可能在表中任何位置上进行,因此需分析算法的平均复杂度.由于插入的位置是随机的,因此,需要分析执行该算法移动数据元素的平均值。
设在第i个位置上作插入的概率为Pi,则平均移动数据元素的次数:假设表中任何位置插入概率是均等的,即Pi=1/ (n+1) ,则:所以顺序表插入算法时间复杂度为:O(n)(2)删除一个元素。
线性表的删除运算是指将表的第i(1≦i≦n)结点删除,使长度为n的线性表:(a1,…a i-1,ai,a i+1…,an)变成长度为n-1的线性表(a1,…a i-1,a i+1,…,an)算法时间复杂度的分析。
与插入运算相同,删除运算的时间也主要消耗在移动表中数据元素上,删除第i个元素时,其后面的元素ai+1-an 都要向前移动一个位置,共移动了n-i 个元素,所以在等概率的情况下,在线性表中删除数据元素所需移动数据元素的期望值,即平均移动数据元素的次数为:7、通常情况下,我们认为在线性表中任何位置删除元素是等概率的,即pi =1/n,则:由此可以看出,在线性表上删除数据元素时大约需要移动表中一半的元素,显然该算法的时间复杂度为O(n)。
8、线性表的顺序表示的特点是用物理位置上的邻接关系来表示结点间的逻辑关系,这一特点使我们可以随机存取表中的任一结点,但它也使得插入和删除操作会移动大量的结点.为避免大量结点的移动,我们介绍线性表的另一种存储方式——链式存储结构,简称为链表(Linked List)。
9、链表是指用一组任意的存储单元来依次存放线性表的数据元素,数据元素的关系须用另外存储单元来表示,这两部分组成数据元素的存储映像,称之为结点(Node)。
它包括两个部分:存储数据元素信息的域(数据域)及存储直接后继的存储位置域(指针域/链域)。
显然,单链表中每个结点的存储地址是存放在其前趋结点next域中,而开始结点无前趋,故应设头指针head指向开始结点。
同时,由于终端结点无后继,故终端结点的指针域为空,即NULL或0,在图中表示为“∧”。
10、有时为方便运算处理,在单链表的第一个结点之前设立一个结点,称之为头结点。
设立头结点的优点:a.由于开始结点的位置被存放在头结点的指针域中,所以在链表的第一个位置上的操作就和在表的其它位置上的操作一致,无需进行特殊处理;b.无论链表是否为空,其头指针是指向头结点的非空指针(空表中头结点的指针域为空),因此空表和非空表的处理也就统一了。
11、由于链表是一种动态管理的存储结构,每个结点需动态产生。
1.)初始化链表InitList( &L)的实现在函数调用时,指针L指向的内容发生了变化,为使得调用函数中头指针变量head获得头结点地址,需传递头指针变量的地址给InitList()函数,而函数中定义指针变量L接受该地址值,从而返回改变后的值。
3)、在第i个元素之前插入元素x。
插入运算是将值为x的新结点插入到表的第i个结点的位置上,即插入到ai-1与ai之间。
时间复杂度:T(n)=O(n)4)、删除第i个元素并由e返回。
时间复杂度T(n)=O(n)12、循环链表(circular linked list):是另一种形式的链式存储结构。
它的特点特点是表中最后一个结点的指针域指向头结点,整个链表形成一个环。
这样,从链表中任一结点出发,顺着指针链都可找到表中其它结点。
循环链表的物理结构及算法与单链表的基本相同,差别仅在于算法中的循环条件不是p或p->next是否为空,而是它们是否等于头指针。
while(p->next!=h){……}13、在很多实际问题中,表的操作常常是在表的首尾位置上进行,此时头指针表示的单循环链表就显得不够方便.如果改用尾指针rear来表示单循环链表,则查找开始结点a1和终端结点an都很方便,它们的存储位置分别是(rear->next)->next和rear,显然,查找时间都是O(1)。
14、双向链表(Double linked list):在单链表的每个结点里再增加一个指向其直接前趋的指针域prior。
这样就形成的链表中有两个方向不同的链,故称为双向链表。
在双向链表中,若d为指向表中某一结点的指针(即d为DuLinkList型变量),则显然有:d->next->prior=d->prior->next=d.1)、双向链表插入运算2)、删除运算15、链式存储结构的典型应用之一是在高等数学的多项式方面。
本节主要讨论采用链表结构表示的一元多项式的操作处理。
在数学上,一个一元多项式Pn(x) 可以表示为:Pn(x)=a0+a1x+a2x2+…+anxn (最多有n+1项)aixi是多项式的第i项(0≤i≤n)。
其中ai为系数,x为自变量,i为指数。
多项式中有n+1个系数,而且是线性排列。
于是可用线性表来表示系数ai :P =(a1,a2,…an)一个多项式由多个aixi (1≤i≤m)项组成,每个多项式项采用以下结点存储:其中,coef数据域存放系数ai;expn数据域存放指数ei;next域是一个链域,指向下一个结点。
由此,一个多项式可以表示成由这些结点链接而成的单链表(假设该单链表是带头结点的单链表)。