- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《数据结构》练习题
第一节 线性表结构
1、 [题目] 一个向量第一个元素的存储地址是100,每个元素的长度为2,则第5个元素的地址是多少? [解答] 第一个元素占地址100和101,依此类推第5个占地址108和109,所以答案为108 2、 [题目] 已知一维数组a[4]的地址为1000,二维数组b[3,2]的地址为2000,数组只存储的数据类型为integer,问数组a[15]和b[5,3](按行方式储存, 二维数组为5行5列)的地址各为多少? [解答] 一个integer数据(-32768~32767)需要16位二进制存储,所以a[15]的地址为1022。 3、 [题目] 采用顺序查找方法查找长度为n的线性表时,每个元素的平均查找长度是多少? [解答] 查找第一个元素的查找长度为1,第二个的长度为2…第n个的长度为n,所以总共长度为,平均长度为。 4、 [题目] 设有一个栈,元素进栈的次序为A,B,C,D,E。试问能否得到出栈序列:1)C,E,A,B,D
2)C,B,A,D,E
3)D,C,A,B,E
4)A,C,B,E,D
5)A,B,C,D,E [解答] ‘’代表进栈,‘’代表出栈,下同
1)不能2)可以按,,,,,,,,,的顺序3)不能4)可以按,,,,,,,,,的顺序5)可以按,,,,,,,,,的顺序 5、 [题目] 设栈S和队列Q的初始状态为空,元素e1,e2,e3,e4,e5和e6依次通过栈S,一个元素出栈后即进入队列Q,若6个元素出队的序列是e2,e4,e3,e6,e5,e1,则栈S的容量至少应该是多少? [解答] 根据栈先进后出以及队列先进先出的特征,可知进出栈的顺序为,,,,,,,,,,,。某一时刻,栈中最多有3个元素,所以栈S的容量至少为3 6、 [题目] 设将整数1.2.3.4依次进栈,但只要出栈时栈非空,则可将出栈操作按任何次序加入其中,请回答下述问题:(1)若入、出栈次序为:
Push(1),Pop(),Push(2),Push(3),Pop(),Pop(),Push(4),Pop(),则出栈的数字序列为何(这里Push(i)表示i进栈,Pop()表示出栈)?(2)能否得到出栈序列1423和1432?并说明为什么不能得到或者如何得到。
(3)请分析1,2,3,4的24种排列中,哪些序列是可以通过相应的入出栈操作得到的。 [解答] (1)1,3,2,4(2)按照,,,,,的顺序可以得到1,4的输出,此时栈中还有2,3。接着只能输出3,2而不能输出2,3。(3)经过观察可以得到如下结论:1.一旦栈中输出了元素n,那么1…n-1这些元素要么已经出栈,要么还按从小到大的顺序存在栈中;2.输出元素n后,比n小的未输出元素只能按从大到小的先后顺序输出。不难得出,可以输出以下序列:
(4,3,2,1)(3,4,2,1)(3,2,4,1)(2,4,3,1)(2,3,4,1)(2,1,4,3)(1,4,3,2)(1,3,4,2) (1,3,2,4)(1,2,4,3)(1,2,3,4) 7、 [题目] 回文是指正读反读均相同的字符序列,如“abba”和“abdba”均是回文,但“good”不是回文。试写一个算法判定给定的字符向量是否为回文。 [解答] 根据提示不难完成。
源程序:huiwen.pas, huiwen.exe
输入:huiwen.in 输出:huiwen.out
输入为一行待判断字符,若有数字仍按字符形式判断 8、 [题目] 线性表用顺序储存,设计一个算法,用尽可能少的辅助存储空间将顺序表中前m个元素和后n个元素进行整体互换。即将线性表(a1,a2,…am,b1,2b,…bn)改变为:(b1,b2,…bn,a1,a2,…am)。 [解答] 以字符串形式进行操作,直接交换。
源程序:huhuan.pas, huhuan.exe
输入:huhuan.in 输出:huhuan.out
输入为一行待判断字符,若有数字仍按字符形式判断 9、 [题目] 写出下列中缀表达式的后缀形式:(1)A*B*C
(2)-A+B-C+D
(3) A* B + C
(4)(A+B)*D+E/(F+A*D)+C [解答] (1)A B * C *(2)A – B + C – D +(3) A B * C +(4)A B + D * E A D * F + / +
第二节 树和二叉树
1、 [题目] 对于三个结点A、B、C,有多少种不同的树? [解答] 如图,直线型的树由于根结点中间结点和末结点的不同可以有3*2=6种不同的树 如图,满二叉树型由于根结点不同可以有3种不同的树(此处没有考虑左右孩子结点的不同)。 2、 [题目] 如果一棵树有n
文档评论(0)