第一章 数据结构基础
- 格式:ppt
- 大小:276.00 KB
- 文档页数:44
《数据结构》课后习题答案(第2版)数据结构课后习题答案(第2版)第一章:基本概念1. 什么是数据结构?数据结构是指数据元素之间的关系,以及相应的操作。
它研究如何组织、存储和管理数据,以及如何进行高效的数据操作。
2. 数据结构的分类有哪些?数据结构可以分为线性结构和非线性结构。
线性结构包括数组、链表、栈和队列;非线性结构包括树和图。
3. 什么是算法?算法是解决特定问题的一系列有序步骤。
它描述了如何输入数据、处理数据,并产生期望的输出结果。
4. 算法的特性有哪些?算法具有确定性、有限性、输入、输出和可行性这五个特性。
5. 数据结构和算法之间的关系是什么?数据结构是算法的基础,算法操作的对象是数据结构。
第二章:线性表1. 顺序表的两种实现方式是什么?顺序表可以通过静态分配或动态分配的方式实现。
静态分配使用数组,动态分配使用指针和动态内存分配。
2. 单链表的特点是什么?单链表由节点组成,每个节点包含数据和一个指向下一个节点的指针。
它的插入和删除操作效率高,但是查找效率较低。
3. 循环链表和双向链表分别是什么?循环链表是一种特殊的单链表,在尾节点的指针指向头节点。
双向链表每个节点都有一个指向前一个节点和后一个节点的指针。
4. 链表和顺序表的区别是什么?链表的插入和删除操作效率更高,但是查找操作效率较低;顺序表的插入和删除操作效率较低,但是查找操作效率较高。
第三章:栈和队列1. 栈是什么?栈是一种特殊的线性表,只能在表的一端进行插入和删除操作。
后进先出(LIFO)是栈的特点。
2. 队列是什么?队列是一种特殊的线性表,只能在表的一端进行插入操作,在另一端进行删除操作。
先进先出(FIFO)是队列的特点。
3. 栈和队列的应用有哪些?栈和队列在计算机科学中有广泛的应用,例如浏览器的前进后退功能使用了栈,操作系统的进程调度使用了队列。
4. 栈和队列有哪些实现方式?栈和队列可以使用数组或链表来实现,还有更为复杂的如双端队列和优先队列。
数据结构课程教案第一章:数据结构概述1.1 数据结构的概念介绍数据结构的基本概念和重要性讨论数据的组织、存储和操作1.2 常见的数据结构线性结构:数组、链表、栈、队列非线性结构:树、图1.3 算法和复杂度介绍算法的概念和设计方法讨论时间复杂度和空间复杂度第二章:线性表2.1 数组介绍数组的概念和实现讨论数组的操作和优缺点2.2 链表介绍链表的概念和实现讨论链表的操作和优缺点2.3 栈和队列介绍栈和队列的概念和实现讨论栈和队列的操作和应用场景第三章:非线性结构3.1 树介绍树的概念和性质讨论树的遍历和操作3.2 二叉树介绍二叉树的概念和性质讨论二叉树的遍历和操作3.3 图介绍图的概念和表示方法讨论图的遍历和操作第四章:排序和搜索算法4.1 排序算法介绍排序算法的概念和分类讨论常见的排序算法(如冒泡排序、选择排序、插入排序等)4.2 搜索算法介绍搜索算法的概念和分类讨论常见的搜索算法(如顺序搜索、二分搜索等)第五章:算法设计技巧5.1 分治法介绍分治法的概念和应用讨论分治法的实现和优点5.2 动态规划介绍动态规划的概念和应用讨论动态规划的实现和优点5.3 贪心算法介绍贪心算法的概念和应用讨论贪心算法的实现和优点第六章:线性表的扩展6.1 串介绍串的概念和实现讨论串的操作和应用场景6.2 多维数组和稀疏矩阵介绍多维数组和稀疏矩阵的概念和实现讨论它们的操作和应用场景第七章:树状数组和离散化7.1 树状数组介绍树状数组的概念和实现讨论树状数组的操作和应用场景7.2 离散化介绍离散化的概念和实现讨论离散化的操作和应用场景第八章:排序算法的进阶8.1 快速排序介绍快速排序的概念和实现讨论快速排序的优化和时间复杂度分析8.2 归并排序介绍归并排序的概念和实现讨论归并排序的优化和时间复杂度分析8.3 堆排序介绍堆排序的概念和实现讨论堆排序的优化和时间复杂度分析第九章:高级搜索算法9.1 深度优先搜索(DFS)介绍深度优先搜索的概念和实现讨论深度优先搜索的适用场景和应用9.2 广度优先搜索(BFS)介绍广度优先搜索的概念和实现讨论广度优先搜索的适用场景和应用9.3 A搜索算法介绍A搜索算法的基本概念和实现讨论A搜索算法的优势和应用场景第十章:动态规划的进阶应用10.1 背包问题介绍背包问题的概念和分类讨论动态规划解决背包问题的方法和时间复杂度分析10.2 最长公共子序列和最长公共子串介绍最长公共子序列和最长公共子串的概念和实现讨论它们的适用场景和应用10.3 矩阵链乘问题介绍矩阵链乘问题的概念和实现讨论动态规划解决矩阵链乘问题的方法和时间复杂度分析十一章:图论基础11.1 图的基本概念介绍图的定义、术语和表示方法讨论图的类型和应用场景11.2 图的遍历介绍深度优先搜索(DFS)和广度优先搜索(BFS)讨论图的遍历算法实现和应用11.3 最小树介绍最小树的概念和性质讨论克鲁斯卡尔算法和普里姆算法十二章:网络流和匹配12.1 网络流介绍网络流问题的定义和性质讨论最大流和最小费用流算法12.2 匹配介绍匹配的概念和类型讨论匈牙利算法和最大匹配算法十三章:并查集和路径压缩13.1 并查集的基本概念介绍并查集的数据结构和操作讨论并查集的实现和应用场景13.2 路径压缩介绍路径压缩的概念和实现讨论路径压缩对并查集性能的改进十四章:线段树和树状数组14.1 线段树介绍线段树的概念和性质讨论线段树的构建和操作实现14.2 树状数组回顾树状数组的概念和操作讨论树状数组的应用场景和优势十五章:总结与实践项目15.1 课程总结回顾整个课程的主要概念、算法和应用强调数据结构在软件工程中的重要性15.2 实践项目设计一个或多个综合性的实践项目要求学生应用所学知识解决实际问题这个教案旨在为学生提供一个全面的数据结构学习框架,从基本概念到高级应用,涵盖了各种常见的数据结构和算法。
复习提纲第一章数据构造概述根本概念与术语〔P3〕1.数据构造是一门研究非数值计算程序设计问题中计算机的操作对象以及他们之间的关系和操作的学科.2.数据是用来描述现实世界的数字,字符,图像,声音,以及能够输入到计算机中并能被计算机识别的符号的集合2.数据元素是数据的根本单位3.数据对象一样性质的数据元素的集合4.数据构造三方面容:数据的逻辑构造.数据的存储构造.数据的操作.〔1〕数据的逻辑构造指数据元素之间固有的逻辑关系.〔2〕数据的存储构造指数据元素及其关系在计算机的表示( 3 ) 数据的操作指在数据逻辑构造上定义的操作算法,如插入,删除等.5.时间复杂度分析--------------------------------------------------------------------------------------------------------------------1、名词解释:数据构造、二元组2、根据数据元素之间关系的不同,数据的逻辑构造可以分为集合、线性构造、树形构造和图状构造四种类型。
3、常见的数据存储构造一般有四种类型,它们分别是___顺序存储构造_____、___链式存储构造_____、___索引存储构造_____和___散列存储构造_____。
4、以下程序段的时间复杂度为___O(N2)_____。
int i,j,*;for(i=0;i<n:i++) n+1for(j=0;j<n;j++) n+1*+=i;------------------------------------------------------------------------------------------------------------------第二章线性表1.顺序表构造由n(n>=0)个具有一样性质的数据元素a1,a2,a3……,an组成的有穷序列//顺序表构造#define MA*SIZE 100typedef int DataType;Typedef struct{DataType items[MA*SIZE];Int length;}Sqlist,*LinkList;2.单链表(1)链表结点构造//链表的节点构造Typedef struct Node{int data;struct Node *ne*t;} Lnode,*Pnode,*LinkList;(2)结点遍历void TraverseList(LinkList t){LinkList p;while(t){p=t;t=t->ne*tfree(p);}}(3)链表操作算法:初始化、插入、输出、删除void InitList(LinkList *h){*h=(LinkList)malloc(sizeof(LNode));if(!h){print("初始化错误〞);return;}(*h)->ne*t=NULL;}void InsertList(LinkList h,int pos,datatype *){ LinkList p=h,q;int i=0;while(p&&i<pos-1){p=p->ne*t;i++;}if(!p||i>pos-1)print("插入位置出错!!〞);InitList(&q);q->ne*t=NULL;q->data=*;}void DeleteList(LinkList h,int pos){LinkList p=h,q;int i=0;while(p&&i<pos-1){p=p->ne*t;i++;}if(!p||i>pos-1){cout<<〞删除位置错误〞;return;}q=p->ne*t;p->ne*t=q->ne*t;free(q);}-----------------------------------------------------------------------------------------------------------------1、线性表中,第一个元素没有直接前驱,最后一个元素没有直接后驱。
《数据结构》教案(精华版)《数据结构》教案(精华版)前言数据结构是计算机学科中的重要基础课程,它涉及到数据的存储、组织和管理。
本教案旨在帮助学生掌握数据结构的基本概念、算法和应用,提高其解决实际问题的能力。
第一章:引言在本章中,我们将介绍数据结构的基本概念和重要性。
学生将了解到数据结构在计算机科学中的作用,以及为什么学习数据结构对于他们的职业发展至关重要。
1.1 数据结构的定义数据结构是一种组织和存储数据的方式,它涉及到数据元素之间的关系,以及对这些关系的操作。
1.2 数据结构的分类数据结构可以分为线性结构和非线性结构。
线性结构中的数据元素之间存在一个明确的顺序关系,而非线性结构中的数据元素之间没有固定的顺序关系。
1.3 数据结构的应用数据结构在计算机科学中有广泛的应用。
例如,在数据库管理系统中,数据结构被用来组织和管理大量的数据;在图形图像处理中,数据结构被用来存储和操作图像数据。
第二章:线性结构本章将介绍线性结构,包括线性表、栈和队列。
学生将学习这些线性结构的定义、实现和应用。
2.1 线性表线性表是一种最简单的数据结构,它由一组数据元素组成,这些元素按照线性的顺序存储。
2.2 栈栈是一种特殊的线性表,它具有“先进后出”的特点。
学生将学习栈的定义、实现和常见应用。
2.3 队列队列是另一种特殊的线性表,它具有“先进先出”的特点。
学生将学习队列的定义、实现和应用。
第三章:树结构本章将介绍树结构,包括二叉树、搜索树和平衡树。
学生将学习这些树结构的定义、实现和应用。
3.1 二叉树二叉树是一种常见的树结构,它的每个节点最多有两个子节点。
学生将学习二叉树的定义、实现和遍历算法。
3.2 搜索树搜索树是一种特殊的二叉树,它的每个节点都符合一定的大小关系。
学生将学习搜索树的定义、实现和查找算法。
3.3 平衡树平衡树是一种自平衡的二叉树,它可以保持树的高度平衡。
学生将学习平衡树的定义、实现和平衡算法。
第四章:图结构本章将介绍图结构,包括无向图和有向图。
第一章数据结构1.定义数据结构是计算机存储、组织数据的方式.数据结构是抽象数据类型的物理实现.2.数据结构包括如下几个方面:(1)数据元素之间的逻辑关系,即数据的逻辑结构。
(2) 数据元素及其关系在计算机存储器中的存储方式,即数据的存储结构,也称为数据的物理结构。
(3) 施加在该数据上的操作,即数据的运算。
2。
逻辑结构类型(1)集合结构。
交通工具的集合,动物的集合(2) 线性结构。
一对一,综合素质测评产生的学生排名(3)树形结构。
一对多,单位的组织结构图,族谱(4)图形结构.多对多,生产流程、施工计划、网络建设图等3.存储结构类型(1) 顺序存储方法。
数组(2) 链式存储方法。
链表(3) 索引存储方法(4) 散列存储方法4.算法通常把具体存储结构上的操作实现步骤或过程称为算法。
C语言里通常表现为解决问题的步骤程序= 算法(加工数据)+ 数据结构(数据的存储和组织)5.算法的五个特征(1) 有穷性:在有穷步之后结束。
(2)确定性:无二义性.(3)可行性:可通过基本运算有限次执行来实现。
(4)有输入:可有零个或多个.(5)有输出:至少有一个输出。
6.算法分析(1)时间复杂度:(算法的工作量大小)通常把算法中包含基本运算次数的多少称为算法的时间复杂度,也就是说,一个算法的时间复杂度是指该算法的基本运算次数.算法中基本运算次数T(n)是问题规模n的某个函数f(n),记作:T(n)=O(f(n))(2) 空间复杂度:实现算法所需的存储单元多少第二章线性表1.线性表的基本概念线性表是具有相同特性的数据元素的一个有限序列.该序列中所含元素的个数叫做线性表的长度,用n 表示,n≥0。
2。
线性结构的基本特征为:(1) 集合中必存在唯一的一个“第一元素"; (2) 集合中必存在唯一的一个“最后元素”;(3) 除最后一个元素之外,均有唯一的后继(后件); (4) 除第一个元素之外,均有唯一的前驱(前件)。
数据结构教案清华大学第一章:引言1.1 数据结构的概念数据结构的定义数据的两种类型:标量数据和向量数据数据结构的基本概念1.2 数据结构的应用排序和搜索算法栈和队列的应用链表的应用图的应用1.3 数据结构的设计线性数据结构非线性数据结构树和森林图的表示和遍历第二章:线性表2.1 线性表的概念线性表的定义线性表的性质线性表的抽象数据类型2.2 线性表的实现顺序存储结构链式存储结构线性表的顺序存储实现线性表的链式存储实现2.3 线性表的操作线性表的插入和删除操作线性表的查找和排序操作线性表的逆序输出第三章:栈和队列3.1 栈的概念栈的定义栈的性质栈的抽象数据类型3.2 栈的实现顺序栈的实现链式栈的实现栈的操作实现3.3 队列的概念队列的定义队列的性质队列的抽象数据类型3.4 队列的实现顺序队列的实现链式队列的实现队列的操作实现第四章:串4.1 串的概念串的定义串的性质串的抽象数据类型4.2 串的实现串的顺序存储实现串的链式存储实现串的操作实现4.3 串的模式匹配朴素的模式匹配算法KMP模式匹配算法BM模式匹配算法第五章:数组和稀疏矩阵5.1 数组的概念数组的定义数组的性质数组的抽象数据类型5.2 数组的实现数组的顺序存储实现数组的链式存储实现数组的操作实现5.3 稀疏矩阵的概念稀疏矩阵的定义稀疏矩阵的性质稀疏矩阵的抽象数据类型5.4 稀疏矩阵的实现稀疏矩阵的压缩存储实现稀疏矩阵的运算实现稀疏矩阵的逆矩阵计算这五个章节涵盖了数据结构的基本概念、线性表、栈和队列、串、数组和稀疏矩阵等内容,为学生提供了数据结构的基础知识。
希望这些教案能够帮助学生理解数据结构的重要性和应用,并能够熟练地运用相关算法解决问题。
第六章:树和二叉树6.1 树的概念树的基本概念树的性质树的抽象数据类型6.2 二叉树的概念二叉树的定义二叉树的性质二叉树的抽象数据类型6.3 二叉树的遍历前序遍历中序遍历后序遍历层序遍历6.4 线索二叉树线索二叉树的概念线索二叉树的操作线索二叉树的遍历第七章:图7.1 图的概念图的定义图的性质图的抽象数据类型7.2 图的表示邻接矩阵邻接表逆邻接表7.3 图的遍历深度优先搜索广度优先搜索最短路径算法7.4 最小树最小树的定义普里姆算法克鲁斯卡尔算法第八章:排序算法8.1 排序的概念排序的定义排序的性质排序的抽象数据类型8.2 内部排序算法冒泡排序选择排序插入排序快速排序归并排序堆排序8.3 外部排序算法外部排序的概念外部排序的策略外部排序的算法实现第九章:查找算法9.1 查找的概念查找的定义查找的性质查找的抽象数据类型9.2 内部查找算法顺序查找二分查找分块查找9.3 哈希查找哈希的概念哈希函数的设计哈希查找的实现9.4 索引查找索引的概念索引的实现索引查找的算法实现第十章:动态规划10.1 动态规划的概念动态规划的定义动态规划的性质动态规划的抽象数据类型10.2 动态规划的应用背包问题最长公共子序列最短路径问题股票买卖问题10.3 动态规划的算法实现动态规划算法的框架动态规划算法的实现技巧动态规划算法的优化重点和难点解析一、线性表的实现线性表的顺序存储实现:如何合理地分配数组的大小,以及如何进行数据的插入和删除操作。
数据是描述客观事物的数值、字符以及能输入机器且能被处理的各种符号集合。
换句话说,数据是对客观事物采用计算机能够识别、存储和处理的形式所进行的描述;是计算机加工处理的对象。
包括数值、字符、声数据元素是组成数据的基本单位一个数据元素可由若干个数据项组成()数据对象是性质相同的数据元素的集合,是数据的一个子集。
…},字母字符数据对象是集合象。
由此可看出,不论数据元素集合是无限集(如整数集)Data Structure)数据元素相互之间的关系称为结构( Structure ),有四种基本结构。
集合结构:结构中的数据元素之间除了同属于一个集合的关系外,无任何其它关系。
线性结构:结构中的数据元素之间存在着一对一的线性关系。
图状结构或网状结构:结构中的数据元素之间存在着多对多的任意关系。
为数据结构的有限集,S是D上关系的有限集。
表示复数的虚部。
存储结构(又称物理结构)是逻辑结构在计算机中的存储映象,是逻辑结构在计算机中的实现,它包括据元素的表示和关系的表示形式化描述:要存入机器中,建立一从,使S(D逻辑结构与存储结构的关系为:数据结构的内容可归纳为三个部分:逻辑结构、存储结构和运算集合。
按某种逻辑关系组织起来的一批数据,按一定的映象方式把它存放在计算机的存储器中,并在这些数据上定义了一个运算的集合,(Data Type)数据类型是一组性质相同的值集合以及定义在这个值集合上的一组操作的总称合,即该类型的取值范围,以及该类型中可允许使用的一组运算。
例如高级语言中的数据类型就是已经实现的从这个意义上讲,数据类型是高级语言中允许的变量种类,计算机中使用的是二进制数,汇编语言中则可给出各种数据的十进制表示,如二进制数据的抽象; 使用者在编程时可以直接使用据抽象,出现了数据类型,(Abstract Data Type))是指基于一类逻辑关系的数据类型以及定义在这个类型之上的一组操作。
抽象数据类型的定义取决于客观存在的一组逻辑特性,而与其在计算机内如何表示和实现无关,即不论其内部结构如何变化,只要它的数学特性不变,都不影响其外部使用。
一、判断题(第一章绪论)1.数据元素是数据的最小单元。
答案:错误2.一个数据结构是由一个逻辑结构和这个逻辑结构上的基本运算集构成的整体。
答案:错误3.数据的存储结构是数据元素之间的逻辑关系和逻辑结构在计算机存储器内的映像。
答案:正确4.数据的逻辑结构是描述元素之间的逻辑关系,它是依赖于计算机的。
答案:错误5.用语句频度来表示算法的时间复杂度的最大好处是可以独立于计算机的软硬件,分析算法的时间答案:正确(第二章线性表)6.取顺序存储线性表的第i个元素的时间同i的大小有关。
答案:错误7.线性表链式存储的特点是可以用一组任意的存储单元存储表中的数据元素。
答案:正确8.线性链表的每一个节点都恰好包含一个指针域。
答案:错误9.顺序存储方式的优点的存储密度大,插入和删除效率不如练市存储方式好。
答案:正确10.插入和删除操作是数据结构中最基本的两种操作,所以这两种操作在数组中也经常使用。
答案:错误(第三章栈)11.栈是一种对进栈和出栈作了限制的线性表。
答案:错误12.在C(或C++)语言中设顺序栈的长度为MAXLEN,则top=MAXLEN表示栈满。
答案:错误13.链栈与顺序栈相比,其特点之一是通常不会出现满栈的情况。
答案:正确14.空栈就是所有元素都为0上的栈。
答案:错误15.将十进制数转换为二进制数是栈的典型应用之一。
答案:正确(第四章队列)16.队列式限制在两端进行操作的线性表。
答案:正确17.判断顺序队列为空的标准是头指针和尾指针都指向同一结点。
答案:错误18.在循环链列队中无溢出现像。
答案:错误19.在循环队列中,若尾指针rear大于头指针front,则元素个数为rear-front。
答案:正确20.顺序队列和循环队列关于队满和队空的判断条件是一样的。
答案:错误(第五章串)21.串是n个字母的有限序列。
答案:错误22.串的堆分配存储是一种动态存储结构。
答案:正确23.串的长度是指串中不同字符的个数。
一、判断题(第一章绪论)1、数据元素就是数据得最小单元。
答案:错误2.一个数据结构就是由一个逻辑结构与这个逻辑结构上得基本运算集构成得整体。
答案:错误3.数据得存储结构就是数据元素之间得逻辑关系与逻辑结构在计算机存储器内得映像。
答案:正确4.数据得逻辑结构就是描述元素之间得逻辑关系,它就是依赖于计算机得。
答案:错误5、用语句频度来表示算法得时间复杂度得最大好处就是可以独立于计算机得软硬件,分析算法得时间答案:正确(第二章线性表)6、取顺序存储线性表得第i个元素得时间同i得大小有关。
答案:错误7、线性表链式存储得特点就是可以用一组任意得存储单元存储表中得数据元素。
答案:正确8、线性链表得每一个节点都恰好包含一个指针域。
答案:错误9、顺序存储方式得优点得存储密度大,插入与删除效率不如练市存储方式好。
答案:正确10、插入与删除操作就是数据结构中最基本得两种操作,所以这两种操作在数组中也经常使用。
答案:错误(第三章栈)11、栈就是一种对进栈与出栈作了限制得线性表。
答案:错误12、在C(或C++)语言中设顺序栈得长度为MAXLEN,则top=MAXLEN表示栈满。
答案:错误13、链栈与顺序栈相比,其特点之一就是通常不会出现满栈得情况。
答案:正确14、空栈就就是所有元素都为0上得栈。
答案:错误15、将十进制数转换为二进制数就是栈得典型应用之一。
答案:正确(第四章队列)16、队列式限制在两端进行操作得线性表。
答案:正确17、判断顺序队列为空得标准就是头指针与尾指针都指向同一结点。
答案:错误18、在循环链列队中无溢出现像。
答案:错误19、在循环队列中,若尾指针rear大于头指针front,则元素个数为rear-front。
答案:正确20、顺序队列与循环队列关于队满与队空得判断条件就是一样得。
答案:错误(第五章串)21、串就是n个字母得有限序列。
答案:错误22、串得堆分配存储就是一种动态存储结构。
答案:正确23、串得长度就是指串中不同字符得个数。
第一章数据结构一、选择题(1)下列数据结构中,能用二分法进行查找的是A)顺序存储的有序线性表 B)线性链表C)二叉链表 D)有序线性链表【答案】A【解析】二分查找只适用于顺序存储的有序表。
在此所说的有序表是指线性表中的元素按值非递减排列(即从小到大.但允许相邻元素值相等)的。
选项A正确。
(2)下列关于栈的描述正确的是A)在栈中只能插入元素而不能删除元素B)在栈中只能删除元素而不能插入元素C)栈是特殊的线性表,只能在一端插入或删除元素D)栈是特殊的线性表,只能在一端插入元素,而在另一端删除元素【答案】C【解析】栈是一种特殊的线性表,其插入与删除运算都只在线性表的一端进行。
由此可见,选项A、选项B和选项D错误,正确答案是选项C。
(3)下列叙述中正确的是A)一个逻辑数据结构只能有一种存储结构B)数据的逻辑结构属于线性结构,存储结构属于非线性结构C)一个逻辑数据结构可以有多种存储结构,且各种存储结构不影响数据处理的效率D)一个逻辑数据结构可以有多种存储结构,且各种存储结构影响数据处理的效率【答案】D【解析】一般来说,一种数据的逻辑结构根据需要可以表示成多种存储结构,常用的存储结构有顺序、链接、索引等存储结构。
而采用不同的存储结构,其数据处理的效率是不同的。
由此可见,选项D的说法正确。
(4)算法执行过程中所需要的存储空间称为算法的A)时间复杂度B)计算工作量C)空间复杂度D)工作空间【答案】c【解析】算法执行时所需要的存储空间,包括算法程序所占的空间、输入的初始数据所占的存储空间以及算法执行过程中所需要的额外空间,其中额外空间还包括算法程序执行过程的工作单元以及某种数据结构所需要的附加存储空间。
这些存储空间共称为算法的空间复杂度。
(5)下列关于队列的叙述中正确的是A)在队列中只能插入数据B)在队列中只能删除数据C)队列是先进先出的线性表D)队列是先进后出的线性表【答案】c【解析】对队列可以进行插入和删除数据的操作,只是插入数据只能在队尾,删除数据只能在队头。