河南理工大学数据结构实验报告

河南理工大学数据结构实验报告
河南理工大学数据结构实验报告

河南理工大学数据结构实验报告

篇一:《数据结构》第四章习题参考答案

《数据结构》第四章习题

一、判断题(在正确说法的题后括号中打“√”,错误说法的题后括号中打“×”)

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.BCDEF B.BCDEFG C.BCPQRST D.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.8 B.9 C.10 D.11

2.树的后根遍历序列等同于该树对应的二叉树的。

A. 先序序列

B. 中序序列

C. 后序序列

3、二叉树的先序遍历和中序遍历如下:先序遍历:EFHIGJK;中序遍历:HFIEJKG 。该二叉树根的右子树的根是:A. EB. F C. G D. 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 的两个结点处于同一层的条件是「_2 2_。

?4、某二叉树有20个叶子结点,有30个结点仅有一个孩子,则该二叉树的总结点数为。(n=n0+n1+n2)

5、完全二叉树中,结点个数为n,则编号最大的分支结点的编号为______。

6、已知二叉树前序为ABDEGCF,中序为DBGEACF,则后序一定是___。

四、综合题

1、设二叉树采用二叉链表存储结构,结点的数据域data为字符类型。阅读下列算法,并回答问题:

(1)对于如图所示的二叉树,写出执行函数function的输出结果;(2)简述函数function的功能。

void function {

Stack S; BinTreeNode* p = ;

BinTreeNode* q; if return; do {

while {

;

if p=p->leftChild; else p=p->rightChild; }

while && q= && q-> rightChild = =p){

p=; cout data; }

if){

q=; p=q-> rightChild; }

} while ); }

1

DBFGECA

函数function的功能是对二叉树进行后序遍历。

2、课本P246 题

解答

3、课本P246 题

解答结点个数为n时,深度最小的树的深度为2;它有n-1个叶结点,1个分支结点;深度最大的树的深度为n;它有1个叶结点,n-1个分支结点。

解答

总结点数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)√

(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-20 Huffman树

13、课本P248 题

各字母的Huffman编码:C1: 0110 C2: 10 C3: 0000 C4: 0111 C5: 001 C6: 010 C7: 11

C8: 0001

电文总码长=4×(3+4+5+6)+3×(10+11)

+2×(25+36)=257

14、课本P248 题

解答

统计二叉树中叶结点个数

int BinaryTree :: leaf { }

if return 0;

else if return 1; else return leaf + leaf ;

交换每个结点的左子女和右子女

void BinaryTree :: exchange { BinTreeNode * temp;

if {

}

temp = ptr->leftChild;

ptr->leftChild = ptr->rightChild; ptr->rightChild = temp; exchange ; exchange ; }

15、课本P248 题

解答

template

void BinaryTree :: ConstructTree { //私有函数: 将用T[n]顺序存储的完全二叉树, 以i为根的子树转换成为用二叉链表表示的//以ptr为根的完全二叉树。利用引用型参数ptr将形参的值带回实参。

if ptr = NULL; else {

ptr = new BinTreeNode ; //建立根结点ConstructTree ; ConstructTree ; } }

16、课本P249 题

解答

template void BinaryTree::FullBinTree2Array{ Queue *> Q; BinTreeNode * p = GetRoot; ; int index = 0; }

while){ p = ; }

T[index++]=p->data;

if ; if ;

17、课本P250 题

/

/缩格文本显示树template

void BinaryTree :: FormatDisplay { Stack * > S; ;

相关主题
相关文档
最新文档