数据结构(C语言版~)(第2版~)课后习题-答案~.doc
《数据结构(C语言版~)(第2版~)课后习题-答案~.doc》由会员分享,可在线阅读,更多相关《数据结构(C语言版~)(第2版~)课后习题-答案~.doc(76页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。
1、|数据结构(C语言版) (第2版)课后习题答案李冬梅 2015.3|目 录第 1 章 绪论 .1第 2 章 线性表 .5第 3 章 栈和队列 .13第 4 章 串、数组和广义表 .26第 5 章 树和二叉树 .33第 6 章 图 .43第 7 章 查找 .54第 8 章 排序 .65|第 1 章 绪论1简述下列概念:数据、数据元素、数据项、数据对象、数据结构、逻辑结构、存储结构、抽象数据类型。答案:数据:是客观事物的符号表示,指所有能输入到计算机中并被计算机程序处理的符号的总称。如数学计算中用到的整数和实数,文本编辑所用到的字符串,多媒体程序处理的图形、图像、声音、动画等通过特殊编码定义后的数
2、据。数据元素:是数据的基本单位,在计算机中通常作为一个整体进行考虑和处理。在有些情况下,数据元素也称为元素、结点、记录等。数据元素用于完整地描述一个对象,如一个学生记录,树中棋盘的一个格局(状态)、图中的一个顶点等。数据项:是组成数据元素的、有独立含义的、不可分割的最小单位。例如,学生基本信息表中的学号、姓名、性别等都是数据项。数据对象:是性质相同的数据元素的集合,是数据的一个子集。例如:整数数据对象是集合N=0,1,2,字母字符数据对象是集合 C=A, B, Z, a , b, z,学生基本信息表也可是一个数据对象。数据结构:是相互之间存在一种或多种特定关系的数据元素的集合。换句话说,数据结
3、构是带“结构”的数据元素的集合, “结构”就是指数据元素之间存在的关系。逻辑结构:从逻辑关系上描述数据,它与数据的存储无关,是独立于计算机的。因此,数据的逻辑结构可以看作是从具体问题抽象出来的数学模型。存储结构:数据对象在计算机中的存储表示,也称为物理结构。抽象数据类型:由用户定义的,表示应用问题的数学模型,以及定义在这个模型上的一组操作的总称。具体包括三部分:数据对象、数据对象上关系的集合和对数据对象的基本操作的集合。2试举一个数据结构的例子,叙述其逻辑结构和存储结构两方面的含义和相互关系。答案:例如有一张学生基本信息表,包括学生的学号、姓名、性别、籍贯、专业等。每个学生基本信息记录对应一个
4、数据元素,学生记录按顺序号排列,形成了学生基本信息记录的线性序列。对于整个表来说,只有一个开始结点(它的前面无记录)和一个终端结点(它的后面无记录),其他的结点则各有一个也只有一个直接前趋和直接后继。学生记录之间的这种关系就确定了学生表的逻辑结构,即线性结构。这些学生记录在计算机中的存储表示就是存储结构。如果用连续的存储单元(如用数组表示)来存放这些记录,则称为顺序存储结构;如果存储单元不连续,而是随机存放各个记录,然后用指针进行链接,则称为链式存储结构。即相同的逻辑结构,可以对应不同的存储结构。3简述逻辑结构的四种基本关系并画出它们的关系图。答案:|(1)集合结构数据元素之间除了“属于同一集
5、合”的关系外,别无其他关系。例如,确定一名学生是否为班级成员,只需将班级看做一个集合结构。(2)线性结构数据元素之间存在一对一的关系。例如,将学生信息数据按照其入学报到的时间先后顺序进行排列,将组成一个线性结构。(3)树结构数据元素之间存在一对多的关系。例如,在班级的管理体系中,班长管理多个组长,每位组长管理多名组员,从而构成树形结构。(4)图结构或网状结构数据元素之间存在多对多的关系。例如,多位同学之间的朋友关系,任何两位同学都可以是朋友,从而构成图形结构或网状结构。其中树结构和图结构都属于非线性结构。4存储结构由哪两种基本的存储方法实现?答案:(1)顺序存储结构顺序存储结构是借助元素在存储
6、器中的相对位置来表示数据元素之间的逻辑关系,通常借助程序设计语言的数组类型来描述。(2)链式存储结构顺序存储结构要求所有的元素依次存放在一片连续的存储空间中,而链式存储结构,无需占用一整块存储空间。但为了表示结点之间的关系,需要给每个结点附加指针字段,用于存放后继元素的存储地址。所以链式存储结构通常借助于程序设计语言的指针类型来描述。5选择题(1)在数据结构中,从逻辑上可以把数据结构分成( ) 。A动态结构和静态结构 B紧凑结构和非紧凑结构C线性结构和非线性结构 D内部结构和外部结构四类基本逻辑结构关系图|答案:C(2)与数据元素本身的形式、内容、相对位置、个数无关的是数据的( ) 。A存储结
7、构 B存储实现C逻辑结构 D运算实现答案:C(3)通常要求同一逻辑结构中的所有数据元素具有相同的特性,这意味着( ) 。A数据具有同一特点B不仅数据元素所包含的数据项的个数要相同,而且对应数据项的类型要一致C每个数据元素都一样D数据元素所包含的数据项的个数要相等答案:B(4)以下说法正确的是( ) 。A数据元素是数据的最小单位B数据项是数据的基本单位C数据结构是带有结构的各数据项的集合D一些表面上很不相同的数据可以有相同的逻辑结构答案:D解释:数据元素是数据的基本单位,数据项是数据的最小单位,数据结构是带有结构的各数据元素的集合。(5)算法的时间复杂度取决于( ) 。A问题的规模 B待处理数据
8、的初态C计算机的配置 DA 和 B答案:D解释:算法的时间复杂度不仅与问题的规模有关,还与问题的其他因素有关。如某些排序的算法,其执行时间与待排序记录的初始状态有关。为此,有时会对算法有最好、最坏以及平均时间复杂度的评价。(6)以下数据结构中, ( )是非线性数据结构A树 B字符串 C队列 D栈答案:A6试分析下面各程序段的时间复杂度。(1)x=90; y=100; while(y0)if(x100)x=x-10;y-;else x+;答案:O(1)解释:程序的执行次数为常数阶。(2)for (i=0; i1y=0;while(x(y+1)* (y+1)y+;答案:O( )n解释:语句 y+;
9、的执行次数为 。n|第 2 章 线性表1选择题(1)顺 序 表 中 第 一 个 元 素 的 存 储 地 址 是 100, 每 个 元 素 的 长 度 为 2, 则 第 5 个 元 素 的 地 址 是( ) 。A110 B108 C100 D120答案:B解释:顺序表中的数据连续存储,所以第 5 个元素的地址为:100+2*4=108。(2)在 n 个结点的顺序表中,算法的时间复杂度是 O(1)的操作是( ) 。A访问第 i 个结点(1in)和求第 i 个结点的直接前驱(2in) B在第 i 个结点后插入一个新结点(1in)C删除第 i 个结点(1in)D将 n 个结点从小到大排序答案:A解释:
10、在顺序表中插入一个结点的时间复杂度都是 O(n2),排序的时间复杂度为 O(n2)或O(nlog2n)。顺序表是一种随机存取结构,访问第 i 个结点和求第 i 个结点的直接前驱都可以直接通过数组的下标直接定位,时间复杂度是 O(1)。(3) 向一个有 127 个元素的顺序表中插入一个新元素并保持原来顺序不变,平均要移动 的元素个数为( ) 。A8 B63.5 C63 D7答案:B解释:平均要移动的元素个数为:n/2 。(4)链接存储的存储结构所占存储空间( ) 。A分两部分,一部分存放结点值,另一部分存放表示结点间关系的指针B只有一部分,存放结点值C只有一部分,存储表示结点间关系的指针D分两部
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 语言版 课后 习题 答案
限制150内