河南理工大学数据结构实验报告.docx
- 文档编号:25081775
- 上传时间:2023-06-04
- 格式:DOCX
- 页数:10
- 大小:19.86KB
河南理工大学数据结构实验报告.docx
《河南理工大学数据结构实验报告.docx》由会员分享,可在线阅读,更多相关《河南理工大学数据结构实验报告.docx(10页珍藏版)》请在冰豆网上搜索。
河南理工大学数据结构实验报告
河南理工大学数据结构实验报告
篇一:
《数据结构》第四章习题参考答案
《数据结构》第四章习题
一、判断题(在正确说法的题后括号中打“√”,错误说法的题后括号中打“×”)
1、KMP算法的特点是在模式匹配时指示主串的指针不会变小。
2、串是一种数据对象和操作都特殊的线性表。
3、只包含空白字符的串称为空串(空白串)。
4、稀疏矩阵压缩存储后,必会(不会)失去随机存取功能。
5、使用三元组表示稀疏矩阵的非零元素能节省存储空间。
6、插入与删除操作是数据结构中最基本的两种操作,因此这两种操作在数组中
也经常使用。
(×)
7、若采用三元组表存储稀疏矩阵,只要把每个元素的行下标和列下标互换(错
的),就完成了对该矩阵的转置运算。
(×)
二、单项选择题
1.下面关于串的的叙述中,哪一个是不正确的?
(B)
A.串是字符的有限序列B.空串是由空格构成的串(空串是长度为零的串)
C.模式匹配是串的一种重要运算D.串既可以采用顺序存储,也可以采用链式存储
2.有串S1=’ABCDEFG’,S2=’PQRST’,假设函数con返回x和y串的连接串,subs
返回串s的从序号i的字符开始的j个字符组成的子串,len返回中s的长度,则
con),subs,2))的结果串是(D)。
A.BCDEFB.BCDEFGC.BCPQRSTD.CDEFGFG
3、串的长度是指(B)
A.串中所含不同字母的个数B.串中所含字符的个数
C.串中所含不同字符的个数D.串中所含非空格字符的个数
三、填空题
1、串是一种特殊的线性表,其特殊性表现在_数据元素为字符,操作集也不同__;串的两种最基本的存储方式是_顺序存储_、__链式存储_;两个串相等的
充分必要条件是__两串的长度相等且两串中对应位置的字符也相等__。
2、设正文串长度为n,模式串长度为m,则串匹配的KMP算法的时间复杂度为
_O__。
3、模式串P=‘abaabcac’的next函数值序列为___。
4、已知数组A[0..9,0..9]的每个元素占5个存储单元,将其按行优先次序存储
在起始地址为1000的连续的内存单元中,则元素A[6,8]的地址为__1340___。
四、综合题
1、KMP算法较Brute-Force算法有哪些改进?
解答
朴素的模式匹配(Brute-Force)时间复杂度是O(m*n),KMP算法有一定改进,时间复杂度达到O(m+n)。
KMP算法主要优点是主串指针不回溯。
当主串很大不能一次读入内存且经常发生部分匹配时,KMP算法的优点更为突出。
2、课本P183题
解答
A[2][2]=644+2*n+2=676
A[3][3]=644+3*n+3=692
3、课本P184题
解答
三元组表:
row=6,col=7,terms=9
{,,,,,,,}
行指针数组[0,3,4,6,-1,7]二元组{,,,,,,,,}
4、课本P184题
解答
s:
next[-1,0,0,1]
t:
next[-1,0,0,0,1,2,1]
r:
next[-1,0,0,0,0,1,1,2,0,1,2,3,1,2,1,1,0,0,1,0,0]
5、课本P184题
解答略
篇二:
河南理工大学数据库考试填空和简答
1数据库系统一般由以下五个部分组成:
数据库数据库管理系统数据库管理员应用系统和用户。
1.数据模型通常由数据结构数据操作完整性约束三部分组成。
2.在数据库设计的几个阶段中,数据库概念设计是数据库设计的关键。
3.数据恢复的基本原理用一个词来概括就冗余。
4.完整性约束包括试题完整性参照完整性和用户定义完整性。
5.并发控制的主要技术是—封锁。
6.数据库的完整性是指数据的正确性和相容性。
7.数据独立性包括数据逻辑独立性和数据物理独立性。
8.数据依赖是指实体内部各属性值之间的相互依赖又相互制约的关系。
9.数据转储从转储的状态来分,可分为静态转储和动态转储:
从备份的数据量来分,可分为海量转储和增量转储。
简答题
1.数据库系统的主要特点如下:
1)数据结构化2)数据共享性高,冗余度低,易扩充3)数据独立性高4)由DBMS统一管理和控制。
与文件系统的根本区别是数据结构化。
2.基表是实际存在的表,拥有实际存储的数据,在SQL中,一个关系对应一个基表。
而视图是在基表或视图之上导出的,是个虚表,并没有实际存储的数据。
基表是构成模式内容的基本单位,而视图是构成外模式内容的基本单位。
它们的区别和联系:
基表和视图一经定义,均可用于查询;他们之上都可再定义视图;基表一经删除,其上的视图也无所依存。
3:
所谓事务是指用户定义的一个数据库操作薛烈,这些操作要么不做,要么全做,是一个不可分割的工作单位。
事务的四个特性:
原子性,一致性,隔离性,持续性。
4所谓两端锁协议就是所有事务必须分两个阶段对数据项加锁和解锁。
在对任何数据进行读写操作之前,首先要申请并获得对该数据的封锁。
在释放一
个封锁之后,事务不再申请和获得任何其他封锁。
区别联系:
一次封锁法要求每个事务必须一次将所有要使用的数据全部加锁,它遵守两段锁协议,但两段锁协议并不要求事务必须一次将所有要使用
的数据全部加锁,因此遵守两段锁协议的事务可能发生死锁。
5数据库运行中可能产生的故障有哪几类?
哪些故障影响事物的正常执行?
哪些故障破坏数据库的数据?
答:
数据库的运行中可能产生的故障有事务内部故障、系统故障、介质故障和计算机病毒入侵。
其中事物内部故障、系统故障及病毒入侵会影响事务的正常执行;介质故障和计算机病毒入侵会破坏数据库数据。
6简述数据库设计的基本步骤。
答:
数据库设计的基本步骤:
需求分析;概念结构设计;逻辑结构设计;物理结构设计;数据库实施;数据库的运行和维护
篇三:
《数据结构》第五章习题参考答案
《数据结构》第五章习题参考答案
一、判断题(在正确说法的题后括号中打“√”,错误说法的题后括号中打“×”)
1、知道一颗树的先序序列和后序序列可唯一确定这颗树。
2、二叉树的左右子树可任意交换。
(×)
3、任何一颗二叉树的叶子节点在先序、中序和后序遍历序列中的相对次序不发生改变。
(√)4、哈夫曼树是带权路径最短的树,路径上权值较大的结点离根较近。
(√)5、用一维数组存储二叉树时,总是以前序遍历顺序存储结点。
6、完全二叉树中,若一个结点没有左孩子,则它必是叶子结点。
7、一棵树中的叶子数一定等于与其对应的二叉树的叶子数。
(×)8、度为2的树就是二叉树。
(×)
二、单项选择题
1.具有10个叶结点的二叉树中有(B)个度为2的结点。
A.8B.9C.10D.11
2.树的后根遍历序列等同于该树对应的二叉树的。
A.先序序列B.中序序列C.后序序列
3、二叉树的先序遍历和中序遍历如下:
先序遍历:
EFHIGJK;中序遍历:
HFIEJKG。
该二叉树根的右子树的根是:
A.EB.FC.GD.H0
4、在下述结论中,正确的是(D)。
①具有n个结点的完全二叉树的深度k必为┌log2┐;②二叉树的度为2;③二叉树的左右子树可任意交换;④一棵深度为k且有2k-1个结点的二叉树称为满二叉树。
A.①②③B.②③④C.①②④D.①④
5、某二叉树的后序遍历序列与先序遍历序列正好相反,则该二叉树一定是(D)。
A.空或只有一个结点B.完全二叉树
C.二叉排序树D.高度等于其结点数
三、填空题
1、对于一棵具有n个结点的二叉树,对应二叉链接表中指针总数为个,其中个用于指向孩子结点,个指针空闲着。
2、一棵深度为k的满二叉树有k-1______个叶子结点。
3、在完全二叉树中,编号为i和j的两个结点处于同一层的条件是「_22_。
?
4、某二叉树有20个叶子结点,有30个结点仅有一个孩子,则该二
叉树的总结点数为。
(n=n0+n1+n2)
5、完全二叉树中,结点个数为n,则编号最大的分支结点的编号为______。
6、已知二叉树前序为ABDEGCF,中序为DBGEACF,则后序一定是___。
四、综合题
1、设二叉树采用二叉链表存储结构,结点的数据域data为字符类型。
阅读下列算法,并回答问题:
(1)对于如图所示的二叉树,写出执行函数function的输出结果;
(2)简述函数function的功能。
voidfunction{
StackS;BinTreeNode*p=;BinTreeNode*q;ifreturn;do{
while{
;
ifp=p->leftChild;elsep=p->rightChild;}
while&&q=&&q->rightChild==p){
p=;coutdata;}
if){
q=;p=q->rightChild;}
}while);}
1
DBFGECA
函数function的功能是对二叉树进行后序遍历。
2、课本P246题
解答
3、课本P246题
解答结点个数为n时,深度最小的树的深度为2;它有n-1个叶结点,1个分支结点;深度最大的树的深度为n;它有1个叶结点,n-1个分支结点。
4、课本P246题
解答
总结点数n=n0+n1+n2+?
+nm
总分支数e=n-1=n0+n1+n2+?
+nm-1=m*nm+*nm-1+?
+2*n2+n1
m
?
则有n0?
?
?
?
ni?
?
1
?
i?
2
?
5、课本P246题解答略
6、课本P246题
解答
二叉树的前序序列与中序序列相同:
空树或缺左子树的单支树;二叉树的中序序列与后序序列相同:
空树或缺右子树的单支树;二叉树的前序序列与后序序列相同:
空树或只有根结点的二叉树。
7、课本P246题
(1)×
(2)√(3)×(4)√
8、课本P246题
(1)×
(2)×(3)√(4)×
9、课本P247题
解答略
10、课本P247题
11、课本P248题
12、课本P248题
5-19答
WPL=(2+3)×5+6×4+(9+14+15)×3+(16+17)×2=229
5-20Huffman树
13、课本P248题
各字母的Huffman编码:
C1:
0110C2:
10C3:
0000C4:
0111C5:
001C6:
010C7:
11
C8:
0001
电文总码长=4×(3+4+5+6)+3×(10+11)
+2×(25+36)=257
14、课本P248题
解答
统计二叉树中叶结点个数
intBinaryTree:
:
leaf{}
ifreturn0;
elseifreturn1;elsereturnleaf+leaf;
交换每个结点的左子女和右子女
voidBinaryTree:
:
exchange{BinTreeNode*temp;
if{
}
temp=ptr->leftChild;
ptr->leftChild=ptr->rightChild;ptr->rightChild=temp;exchange;exchange;}
15、课本P248题
解答
template
voidBinaryTree:
:
ConstructTree{//私有函数:
将用T[n]顺序存储的完全二叉树,以i为根的子树转换成为用二叉链表表示的//以ptr为根的完全二叉树。
利用引用型参数ptr将形参的值带回实参。
ifptr=NULL;else{
ptr=newBinTreeNode;//建立根结点ConstructTree;ConstructTree;}}
16、课本P249题
解答
templatevoidBinaryTree:
:
FullBinTree2Array{Queue*>Q;BinTreeNode*p=GetRoot;;intindex=0;}
while){p=;}
T[index++]=p->data;
if;if;
17、课本P250题
/
/缩格文本显示树template
voidBinaryTree:
:
FormatDisplay{Stack*>S;;
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 河南 理工大学 数据结构 实验 报告