数据结构C语言版第2版习题答案—严蔚敏.docx

上传人:p** 文档编号:541913 上传时间:2023-10-21 格式:DOCX 页数:75 大小:547.08KB
下载 相关 举报
数据结构C语言版第2版习题答案—严蔚敏.docx_第1页
第1页 / 共75页
数据结构C语言版第2版习题答案—严蔚敏.docx_第2页
第2页 / 共75页
数据结构C语言版第2版习题答案—严蔚敏.docx_第3页
第3页 / 共75页
数据结构C语言版第2版习题答案—严蔚敏.docx_第4页
第4页 / 共75页
数据结构C语言版第2版习题答案—严蔚敏.docx_第5页
第5页 / 共75页
数据结构C语言版第2版习题答案—严蔚敏.docx_第6页
第6页 / 共75页
数据结构C语言版第2版习题答案—严蔚敏.docx_第7页
第7页 / 共75页
数据结构C语言版第2版习题答案—严蔚敏.docx_第8页
第8页 / 共75页
数据结构C语言版第2版习题答案—严蔚敏.docx_第9页
第9页 / 共75页
数据结构C语言版第2版习题答案—严蔚敏.docx_第10页
第10页 / 共75页
亲,该文档总共75页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《数据结构C语言版第2版习题答案—严蔚敏.docx》由会员分享,可在线阅读,更多相关《数据结构C语言版第2版习题答案—严蔚敏.docx(75页珍藏版)》请在第壹文秘上搜索。

1、数据结构(C语言版)(第2版)课后习题答案冬梅2015.3章章章章 2 3 4 5 第第第第线性表4栈和队列13串、数组和广义表26树和二叉树33第1章绪论1 .简述下列概念:数据、数据元素、数据项、数据对象、数据结构、逻辑结构、存储结构、抽象数据类型。答案:数据:是客观事物的符号表示,指所有能输入到计算机中并被计算机程序系理的符号的总称。如数学计算中用到的整数和实数,文本编辑所用到的字符串,多媒体程序欠理的图形、图像、声音、动画等通过特殊编码定义后的数据。数据元素:是数据的基本单位,在计算机常作为一个整体进行考虑和处理。在有些情况下,数据元素也称为元素、结点、记录等。数据元素用于完整地描述一

2、个对象,如一个学生记录,树中棋盘的一个格局(状态)、图中的一个顶点等。数据项:是组成数据元素的、有独立含义的、不可分割的最小单位。例如,学生基本信息表中的学号、性别等都是数据项。数据对象:是性质相同的数据元素的集合,是数据的一个子集。例如:整数数据对象是集合N=0,土1,2,字母字符数据对象是集合C=N,BZ,a,b,z,学生基本信息表也可是一个数据对象。数据结构:是相互之间存在一种或多种特定关系的数据元素的集合。换句话说,数据结构是带“结构”的数据元素的集合,“结构”就是指数据元素之间存在的关系。逻辑结构:从逻辑关系上描述数据,它与数据的存储无关,是独立于计算机的。因此,数据的逻辑结构可以看

3、作是从具体问题抽象出来的数学模型。存储结构:数据对象在计算机中的存储表示,也称为物理结构。抽象数据类型:由用户定义的,表示应用问题的数学模型,以及定义在这个模型上的一组操作的总称。具体包括三部分:数据对象、数据对象上关系的集合和对数据对象的基本操作的集合。2 .试举一个数据结构的例子,叙述其逻辑结构和存储结构两方面的含义和相互关系。答案:例如有一学生基本信息表,包括学生的学号、性别、籍贯、专业等。每个学生基本信息记录对应一个数据元素,学生记录按顺序号排列,形成了学生基本信息记录的线性序列。对于整个表来说,只有一个开始结点(它的前面无记录)和一个终端结点(它的后面无记录),其他的结点则各有一个也

4、只有一个直接前趋和直接后继。学生记录之间的这种关系就确定了学生表的逻辑结构,即线性结构。这些学生记录在计算机中的存储表示就是存储结构。如果用连续的存储单元(如用数组表示)来存放这些记录,则称为顺序存储结构;如果存储单元不连续,而是随机存放各个记录,然后用指针进行,则称为链式存储结构。即相同的逻辑结构,可以对应不同的存储结构。3简述逻辑结构的四种基本关系并画出它们的关系图。答案:)集合结构数据元素之间除了“属于同一集合”的关系外,别无其他关系。例如,确定一名学生是否为班级成员,只需将班级看做一个集合结构。0 )线性结构数据元素之间存在一对一的关系。例如,将学生信息数据按照其入学报到的时间先后顺序

5、进行排列,将组成一个线性结构。0 )树结构数据元素之间存在一对多的关系。例如,在班级的管理体系中,班长管理多个组长,每位组长管理多名组员,从而构成树形结构。0 )图结构或网状结构数据元素之间存在多对多的关系。例如,多位同学之间的朋友关系,任何两位同学都可以是朋友,从而构成图形结构或网状结构。其中树结构和图结构都属于非线性结构。O%8g:4 .存储结构由哪两种基本的存储方法实现?答案:)顺序存储结构顺序存储结构是借助元素在存储器中的相对位置来表示数据元素之间的逻辑关系,通常借助程序设计语言的数组类型来描述。0)链式存储结构顺序存储结构要求所有的元素依次存放在一片连续的存储空间中,而链式存储结构,

6、无需占用一整块存储空间。但为了表示结点之间的关系,需要给每个结点附加指针字段,用于存放后继元素的存储地址。所以链式存储结构通常借助于程序设计语言的指针类型来描述。5 .选择题)在数据结构中,从逻辑上可以把数据结构分成()。A动态结构和静态结构B紧凑结构和非紧凑结构专业资料.C线性结构和非线性结构D部结构和外部结构答案:C0)与数据元素本身的形式、容、相对位置、个数无关的是数据的()。A存储结构B存储实现C逻辑结构D运算实现答案:C)通常要求同一逻辑结构中的所有数据元素具有相同的特性,这意味着()。A数据具有同一特点B不仅数据元素所包含的数据项的个数要相同,而且对应数据项的类型要一致C每个数据元

7、素都一样D数据元素所包含的数据项的个数要相等答案:B)以下说确的是()。A数据元素是数据的最小单位B数据项是数据的基本单位C数据结构是带有结构的各数据项的集合D一些表面上很不相同的数据可以有相同的逻辑结构答案:D解释:数据元素是数据的基本单位,数据项是数据的最小单位,数据结构是带有结构的各数据元素的集合。)算法的时间复杂度取决于()。A.问题的规模B,待处理数据的初态C计算机的配置DA和B答案:D解释:算法的时间复杂度不仅与问题的规模有关,还与问题的其他因素有关。如某些排序的算法,其执行时间与待排序记录的初始状态有关。为此,有时会对算法有最好、最坏以及平均时间复杂度的评价。6 )以下数据结构中

8、,()是非线性数据结构A.树B字符串C-队列D栈答案:A6.试分析下面各程序段的时间复杂度。(1) x=90;y=100;while(yO)if(x100)x=x-10;y;elsex+;答案:O(I)解释:程序的执行次数为常数阶。(2) for(i=0;in;i+)for(j=0;jm;j+)aij=0;答案:0(m*n)解释:语句aij=0;的执行次数为m(3) s=0;fori=0;in;i+)for(j=0;jn;j+)s+=Bij;sum=s;答案:0(112)解释:语句s+=Bij;的执行次数为ip。(4) i=l;while(i=n)i=i*3;答案:OClogn)3解释:语句i

9、=i*3;的执行次数为lgj11(5) x=0;for(i=l;in;i+)for(j=l;jly=0;while(x(y+l)*(y+l)y+;答案:0(6)解释:语句y+;的执行次数为Vw。第2章线性表1 .选择题)顺序表中第一个元素的存储地址是100,每个元素的长度为2,则第5个元素的地址是()。A-110B108C100D120答案:B解释:顺序表中的数据连续存储,所以第5个元素的地址为:100+2*4=108。0)在n个结点的顺序表中,算法的时间复杂度是O(I)的操作是()。A访问第i个结点(IWiWn)和求第i个结点的直接前驱(2WiWn)8 .在第i个结点后插入一个新结点(IWi

10、Wn)C.删除第i个结点(lin)D.将n个结点从小到大排序答案:A解释:在顺序表中插入一个结点的时间复杂度都是0(112),排序的时间复杂度为O(112)或O(nlogj)。顺序表是一种随机存取结构,访问第i个结点和求第i个结点的直接前驱都可以直接通过数组的下标直接定位,时间复杂度是0(1)。0)向一个有127个元素的顺序表中插入一个新元素并保持原来顺序不变,平均要画的元素个数为()。A8B63.5C-63D7答案:B解释:平均要移动的元素个数为:n/2。9 )存储的存储结构所占存储空间()。A分两部分,一部分存放结点值,另一部分存放表示结点间关系的指针B只有一部分,存放结点值C只有一部分,

11、存储表示结点间关系的指针D分两部分,一部分存放结点值,另一部分存放结点所占单元数答案:AQ)线性表若采用链式存储结构时,要求存中可用存储单元的地址()。A必须是连续的B部分地址必须是连续的C一定是不连续的D连续或不连续都可以答案:D)线性表L在()情况下适用于使用链式结构实现。A需经常修改L中的结点值CL中含有大量的结点答案:BB需不断对L进行删除插入DL中结点结构复杂解释:链表最大的优点在于插入和删除时不需要移动数据,直接修改指针即可。0)单链表的存储密度()。A大于1B等于1C小于1D不能确定答案:C解释:存储密度是指一个结点数据本身所占的存储空间和整个结点所占的存储空间之比,假设单链表一

12、个结点本身所占的空间为D,指针域所占的空间为N,则存储密度为:D(D+N),一定小于1。)将两个各有n个元素的有序表归并成一个有序表,其最少的比较次数是()。AnB2nTC2nDn-1答案:A解释:当第一个有序表中所有的元素都小于(或大于)第二个表中的元素,只需要用第二个表中的第一个元素依次与第一个表的元素比较,总计比较n次。0)在一个长度为n的顺序表中,在第i个元素(lWinext=p+l;p-next=s;B(*p).next=s;(*s).next=(*p).next;Cs-next=p-next;-next=s-next;Ds-next=p-next;p-next=s;答案:D(14)在双向链表存储结构中,删除P所指的结点时须修改指针()。Ap-next-prior=p-prior;p-prior-next=p-next;Bp-next=p-next-next;p-next-prior=p;Cp-prior-next=p;p-prior=p-prior-prior;Dp-prior=p-next-next;p-next=p-prior-prior;答案:A(15)在双向循环链表中,在p指针所指的结点后插入q所指向的新结

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > IT计算机 > 数据结构与算法

copyright@ 2008-2023 1wenmi网站版权所有

经营许可证编号:宁ICP备2022001189号-1

本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。第壹文秘仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知第壹文秘网,我们立即给予删除!