数据结构 习题选讲
- 格式:pptx
- 大小:192.98 KB
- 文档页数:49
课后习题讲解(数据结构)第 1 章绪论课后习题讲解1. 填空⑴()是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。
【解答】数据元素⑵()是数据的最小单位,()是讨论数据结构时涉及的最小数据单位。
【解答】数据项,数据元素【分析】数据结构指的是数据元素以及数据元素之间的关系。
⑶ 从逻辑关系上讲,数据结构主要分为()、()、()和()。
【解答】集合,线性结构,树结构,图结构⑷ 数据的存储结构主要有()和()两种基本方法,不论哪种存储结构,都要存储两方面的内容:()和()。
【解答】顺序存储结构,链接存储结构,数据元素,数据元素之间的关系⑸ 算法具有五个特性,分别是()、()、()、()、()。
【解答】有零个或多个输入,有一个或多个输出,有穷性,确定性,可行性⑹ 算法的描述方法通常有()、()、()和()四种,其中,()被称为算法语言。
【解答】自然语言,程序设计语言,流程图,伪代码,伪代码⑺ 在一般情况下,一个算法的时间复杂度是()的函数。
【解答】问题规模⑻ 设待处理问题的规模为n,若一个算法的时间复杂度为一个常数,则表示成数量级的形式为(),若为n*log25n,则表示成数量级的形式为()。
【解答】Ο(1),Ο(nlog2n)【分析】用大O记号表示算法的时间复杂度,需要将低次幂去掉,将最高次幂的系数去掉。
2. 选择题⑴ 顺序存储结构中数据元素之间的逻辑关系是由()表示的,链接存储结构中的数据元素之间的逻辑关系是由()表示的。
A 线性结构B 非线性结构C 存储位置D 指针【解答】C,D【分析】顺序存储结构就是用一维数组存储数据结构中的数据元素,其逻辑关系由存储位置(即元素在数组中的下标)表示;链接存储结构中一个数据元素对应链表中的一个结点,元素之间的逻辑关系由结点中的指针表示。
⑵ 假设有如下遗产继承规则:丈夫和妻子可以相互继承遗产;子女可以继承父亲或母亲的遗产;子女间不能相互继承。
则表示该遗产继承关系的最合适的数据结构应该是()。
《数据结构》习题第一章绪论一、单选或填空题1. 下列程序段中S语句的执行频度为。
for(i=0;i<n;i++ )for(j=0;j<i;j++ )S;2. 下列算法的时间复杂度是()。
for(i=0;i<n;i++ )c[i]=i;3. 算法的时间复杂度可表示为O(1)、线性阶、平方阶O(n2)、对数阶O(logn)和指数阶O(2n)等。
4 以下关于数据结构的基本概念中,叙述正确的是A) 数据元素是数据不可分割的最小单位。
B) 数据是数据对象的子集。
C) 数据元素之间的关系在计算机中可用顺序映像和非顺序映像两种不同的方法表示。
D) 数据结构在计算机中的表示又称为逻辑结构。
5. 在数据结构中,数据的逻辑结构包括()。
A) 线性结构和非线性结构B) 逻辑结构和物理结构C) 顺序结构和链式结构D) 虚拟结构和抽象结构6. 在数据结构中,数据的存储结构包括。
A) 线性结构和非线性结构B)逻辑结构和物理结构C) 顺序结构和链式结构D) 虚拟结构和抽象结构第二章线性表1.线性结构的数据元素之间存在一种( )。
A.一对多关系B.多对多关系C.多对一关系D.一对一关系2. 在长度为n的顺序表中插入一个元素,需要平均移动个元素。
A) n/2 B)nC) n(n-1) D) n(n+1)3. 在有n个元素的顺序表中做插入、删除运算,平均时间复杂度为。
4. 顺序表中逻辑上相邻的元素物理位置相邻,单链表中逻辑上相邻的元素的物理位置相邻。
A)必然、必然B)必然、不一定C)不一定、必然D)不一定、不一定5.相对于顺序存储而言,链式存储的优点是()。
A.随机存取B.节约空间C.增、删操作方便D.节点间关系简单6. 以下关于头结点的描述中,叙述错误..的是A) 头结点是对链表首元结点的别称B) 若链表中附设头结点,则头指针一定不为空C) 头结点中不存储链表的数据元素,而是一些诸如表长之类的辅助信息D) 在单链表中附设头结点,插入或删除首元素时不必进行特殊处理7.已知L是无表头结点的单链表,且P所指结点既不是首元结点,也不是尾元结点,则在P之后插入S所指结点,则执行()。
数据结构试题一、单选题1、在数据结构的讨论中把数据结构从逻辑上分为(C )A 内部结构与外部结构B 静态结构与动态结构C 线性结构与非线性结构D 紧凑结构与非紧凑结构。
2、采用线性链表表示一个向量时,要求占用的存储空间地址(D )A 必须是连续的B 部分地址必须是连续的C 一定是不连续的D 可连续可不连续3、采用顺序搜索方法查找长度为n的顺序表时,搜索成功的平均搜索长度为( D )。
A nB n/2C (n-1)/2D (n+1)/24、在一个单链表中,若q结点是p结点的前驱结点,若在q与p之间插入结点s,则执行( D )。
A s→link = p→link;p→link = s;B p→link = s; s→link = q;C p→link = s→link;s→link = p;D q→link = s;s→link = p;5、如果想在4092个数据中只需要选择其中最小的5个,采用( C )方法最好。
A 起泡排序B 堆排序C 锦标赛排序D 快速排序6、设有两个串t和p,求p在t中首次出现的位置的运算叫做( B )。
A 求子串B 模式匹配C 串替换D 串连接7、在数组A中,每一个数组元素A[i][j]占用3个存储字,行下标i从1到8,列下标j从1到10。
所有数组元素相继存放于一个连续的存储空间中,则存放该数组至少需要的存储字数是( C )。
A 80B 100C 240D 2708、将一个递归算法改为对应的非递归算法时,通常需要使用( A )。
A 栈B 队列C 循环队列D 优先队列9、一个队列的进队列顺序是1, 2, 3, 4,则出队列顺序为( C )。
10、在循环队列中用数组A[0..m-1] 存放队列元素,其队头和队尾指针分别为front和rear,则当前队列中的元素个数是( D )。
A ( front - rear + 1) % mB ( rear - front + 1) % mC ( front - rear + m) % mD ( rear - front + m) % m11、一个数组元素a[i]与( A )的表示等价。
1999-2004年数据结构研究生入学考试题讲解电子科技大学计算机学院尚明生整理一 基本情况1 题型: 单选/多选,填空,解答/简答,算法(修改,填空,设计)2 章节大致分布表1 历年题目章节(大致)分布1999 2000 2001 2002 2003 20040 0 0 2 0 10 Chapter01Chapter02 5 5 8 10 0 20 Chapter03 0 5 5 2 12 100 10 2 1 7 2 Chapter05Chapter06 20 5 25 22 29 12 Chapter07 10 15 6 6 14 2010 5 0 5 14 2 Chapter095 5 3 26 2 Chapter10注: (1)很多题目存在交叉,不完全属于某个章节(2)重点章节是2,6,7,其中2,3章不应分离看待二 试题讲解1.第一章[1999][2000][2001][2002][2分]1.在数据结构中,从逻辑上可以把数据结构分为线性结构和非线性结构。
[2003][2004][10分,10/75]2.线性表有哪两种存储结构?在这两种存储结构中元素之间的逻辑关系分别是通过什么决定的?答:有顺序和链式存储结构,顺序结构中元素之间的逻辑关系由物理存储位置决定,链式结构中元素之间的逻辑关系由链指针决定。
3.对线性表、栈、队列、二叉树、图和广义表六种数据结构,按能表示数据元素之间的最复杂联系在下表中打勾。
多对多较1对多复杂,1对多较1对1复杂。
线性表栈队列二叉树图广义表多对多√√1对多√1对1 √√√【总结】:2.第二章[1999][解答5分,10%]1.阅读下面算法,指出其中的所有的错误。
(5分)FUNC length(head: linklist):integer;{求以head为头指针的不带头结点的循环单链表的长度}f:=head;WHILE f<>head DO [n:=n+1; p:=p↑.link];RETURN(n)ENDF;{length}答:(1)n未初始化为0;(1分)(2)循环条件不对,应为WHILE f↑.link<>head DO(2分)(3)循环变量f的值应在循环体内改变,即p应改为f(1 分)(4)未处理空表的情形(1分)正确的算法是:FUNC length(head: linklist):integer;{求以head为头指针的不带头结点的循环单链表的长度}n:=0;IF head<>NIL THEN [p:=head↑.link; n:=1;WHILE p<>head DO [n:=n+1; p:=p↑.link]];RETURN(n)ENDF;{length}[2000][5分,10%]2.在线性表的顺序和链式存储结构下,试分析下表各种基本运算的时间复杂度,并填入相应的表格中。
一、绪论选择题1.数据结构是一门研究非数值计算的程序设计问题计算机的以及它们之间的和运算等的学科。
1 A.数据元素 B.计算方法 C.逻辑存储 D.数据映像2 A.结构 B.关系 C.运算 D.算法2.数据结构被形式地定义为(K, R),其中K是的有限集,R是K上的有限集。
1 A.算法 B.数据元素 C.数据操作 D.逻辑结构2 A.操作 B.映像 C.存储 D.关系3.在数据结构中,从逻辑上可以把数据结构分成。
A.动态结构和静态结构B.紧凑结构和非紧凑结构C.线性结构和非线性结构D.内部结构和外部结构4.线性结构的顺序存储结构是一种的存储结构,线性表的链式存储结构是一种的存储结构。
A.随机存取B.顺序存取C.索引存取D.散列存取5.算法分析的目的是,算法分析的两个主要方面是。
1 A.找出数据结构的合理性 B.研究算法中的输入和输出的关系C.分析算法的效率以求改进D.分析算法的易懂性和文档性2 A.空间复杂度和时间复杂度 B.正确性和简单性C.可读性和文档性D.数据复杂性和程序复杂性6.计算机算法指的是,它必须具备输入、输出和等5个特性。
1 A.计算方法 B.排序方法 C.解决问题的有限运算序列 D.调度方法2 A.可执行性、可移植性和可扩充性 B.可行性、确定性和有穷性C.确定性、有穷性和稳定性D.易读性、稳定性和安全性7.线性表的逻辑顺序与存储顺序总是一致的,这种说法。
A.正确B.不正确8线性表若采用链式存储结构时,要求内存中可用存储单元的地址。
A.必须连续的B.部分地址必须连续的C.一定是不续的D连续不连续都可以9.以下的叙述中,正确的是。
A.线性表的存储结构优于链式存储结构B.二维数组是其数据元素为线性表的线性表C.栈的操作方式是先进先出D.队列的操作方式是先进后出10.每种数据结构都具备三个基本运算:插入、删除和查找,这种说法。
A.正确B.不正确填空题1.数据逻辑结构包括三种类型、和,树形结构和图形结构合称为。
数据结构题库及答案详解一、选择题1. 在数据结构中,线性结构的特点是什么?A. 结构中存在唯一的开始结点和终端结点B. 结构中所有结点的前驱和后继都存在C. 结构中所有结点都只有一个直接前驱和一个直接后继D. 结构中存在多个开始结点和终端结点答案:C2. 栈是一种特殊的线性表,其特点是:A. 先进先出B. 先进后出C. 可以同时在两端进行插入和删除操作D. 只能在一端进行插入和删除操作答案:D3. 在二叉树的遍历算法中,先序遍历的顺序是:A. 先访问根结点,然后遍历左子树,最后遍历右子树B. 先遍历左子树,然后访问根结点,最后遍历右子树C. 先遍历右子树,然后访问根结点,最后遍历左子树D. 先遍历左右子树,最后访问根结点答案:A二、填空题4. 在图的遍历中,______算法可以避免重复访问同一顶点。
5. 哈希表的冲突可以通过______方法来解决。
答案:4. 深度优先搜索(DFS)5. 链地址法或开放地址法三、简答题6. 简述排序算法中的快速排序算法的基本原理。
答案:快速排序算法是一种分治算法,它通过选择一个元素作为“基准”,然后将数组分为两个子数组,一个包含小于基准的元素,另一个包含大于基准的元素。
然后对这两个子数组递归地应用快速排序算法。
7. 解释什么是递归,并给出一个递归函数的例子。
答案:递归是一种在函数中调用自身的编程技术。
递归函数必须有一个明确的终止条件,以避免无限递归。
例如,计算阶乘的递归函数如下:```int factorial(int n) {if (n == 0) return 1; // 终止条件return n * factorial(n - 1); // 递归调用}```四、编程题8. 编写一个函数,实现单链表的反转。
答案:```c// 假设ListNode是链表节点的定义ListNode* reverseList(ListNode* head) {ListNode* prev = NULL;ListNode* curr = head;ListNode* next = NULL;while (curr != NULL) {next = curr->next; // 保存下一个节点curr->next = prev; // 反转指针prev = curr; // 移动prevcurr = next; // 移动curr}return prev; // 新的头节点}```9. 给定一个整数数组,请实现一个函数来找到数组中的最长连续子序列的长度。
数据结构第六章题⽬讲解02⼀选择题:1、以下说法错误的是①树形结构的特点是⼀个结点可以有多个直接前趋②线性结构中的⼀个结点⾄多只有⼀个直接后继③树形结构可以表达(组织)更复杂的数据④树(及⼀切树形结构)是⼀种"分⽀层次"结构⑤任何只含⼀个结点的集合是⼀棵树2.深度为6的⼆叉树最多有( )个结点①64 ②63 ③32 ④313 下列说法中正确的是①任何⼀棵⼆叉树中⾄少有⼀个结点的度为2②任何⼀棵⼆叉树中每个结点的度都为2 ⼆叉树可空③任何⼀棵⼆叉树中的度肯定等于2 ④任何⼀棵⼆叉树中的度可以⼩于24 设森林T中有4棵树,第⼀、⼆、三、四棵树的结点个数分别是n1,n2,n3,n4,那么当把森林T转换成⼀棵⼆叉树后,且根结点的右⼦树上有()个结点。
①n1-1 ②n1③n1+n2+n3④n2+n3+n4⼆.名词解释:1 结点的度 3。
叶⼦ 4。
分⽀点 5。
树的度三填空题⼆叉树第i(i>=1)层上⾄多有_____个结点。
1、深度为k(k>=1)的⼆叉树⾄多有_____个结点。
2、如果将⼀棵有n个结点的完全⼆叉树按层编号,则对任⼀编号为i(1<=i<=n)的结点X有:若i=1,则结点X是_ ____;若i〉1,则X的双亲PARENT(X)的编号为__ ____。
若2i>n,则结点X⽆_ _____且⽆_ _____;否则,X的左孩⼦LCHILD(X)的编号为____。
若2i+1>n,则结点X⽆__ ____;否则,X的右孩⼦RCHILD(X)的编号为_____。
4.以下程序段采⽤先根遍历⽅法求⼆叉树的叶⼦数,请在横线处填充适当的语句。
Void countleaf(bitreptr t,int *count)/*根指针为t,假定叶⼦数count的初值为0*/ {if(t!=NULL){if((t->lchild==NULL)&&(t->rchild==NULL))__ __;countleaf(t->lchild,&count);countleaf(t->rchild,&count);}}5 先根遍历树和先根遍历与该树对应的⼆叉树,其结果_____。
数据结构试卷(九) 数据结构试卷(十)................ ................22 24 26 27 29 31 33 34 36 37 38 39数据结构试卷(一)参考答案 数据结构试卷(二)参考答案数据结构试卷(三)参考答案 数据结构试卷(四)参考答案 数据结构试卷(五)参考答案 数据结构试卷(六)参考答案 数据结构试卷(七)参考答案 数据结构试卷(八)参考答案 数据结构试卷(九)参考答案 数据结构试卷(十)参考答案........ ........ ........ ........ ........ ........ ........ ........ ........ ........数据结构试卷(一) ...................................数据结构试卷(三) 数据结构试卷(四) 数据结构试卷(五) 数据结构试卷(六) 数据结构试卷(七) 数据结构试卷(八) 0 数据结构试卷(二) 4 7 10 13 15 18 20.................. ................. ................. ................. ................. .................数据结构试卷(一)20 分)A ); 一,单项题(每题 2 分,共 栈和队列的共同特点是 ( A. 只答应在端点处插入和删除元素 B. 都是先进后出 C.都是先进先出 D. 没有共同点1. 用链接方式储备的队列,在进行插入运算时( D ).头,尾指针都要修改仅修改头指针 仅修改尾指针 A. C.B. D. 头,尾指针可能都要修改 2. 以下数据结构中哪一个是非线性结构? ( D )A. 队列 3. 设有一个二维数组B. 栈 A[ m][ n],假设C. 线性表 A[0][0] 存放位置在D. 二叉树644(10),A[2][2] 存放位置在 676(10),每个元素占一个空间,问 ( C );A .688 A[3][3] (10) 存放在什么位置?脚注 (10) 表示用 10 进制表示B . 678 );C . 692D . 696 4. 树最适合用来表示 ( C A. 有序数据元素C. 元素之间具有分支层次关系的数据B. 无序数据元素D.元素之间无联系的数据5. 二叉树的第 k 层的结点数最多为 ( D ).kk-1. 2 -1 A B.2K+1D. 26. 如有 18 个元素的有序表存放在一维数组 中,第一个元素放 A[1] 中,现进行二分A[19] 查找,就查找 A [ 3]的比较序列的下标依次为 ( D ) A. 1 , 2, 3 C. 9, 5, 3 B. 9 , 5, 2, 3D. 9 ,4, 2, 37. 对 n 个记录的文件进行快速排序,所需要的帮助储备空间大致为(C )( n2)( 1) B. O ( n ) C. O ( 1og 2n ) A. O D. O8. 对于线性表( 7,34,55,25,64,46, 20,10)进行散列储备时,如选用 H ( K )=K %9作为散列函数,就散列地址为 1 的元素有( )个,D . 4 ) 条边才能确保是一个连通图;D . 1 . 2 . 3 (A B C9. 设有 6 个结点的无向图,该图至少应有 A三,运算题(每题 1.在如下数组 6 分,共 24 分)A 中链接储备了一个线性表,表头指针为A [0].next ,试写出该线性表; A 0 1 2 3 4 5 6 7data605078903440next 35720410 1 1 11111111111111线性表为:(78,50,40,60,34,90 )2. 请画出下图的邻接矩阵和邻接表;3. 已知一个图的顶点集V 和边集E 分别为:V={1,2,3,4,5,6,7};E={(1,2)3,(1,3)5,(1,4)8,(2,5)10,(2,3)6,(3,4)15,(3,5)12,(3,6)9,(4,6)4,(4,7)20,(5,6)18,(6,7)25};用克鲁斯卡尔算法得到最小生成树,试写出在最小生成树中依次得到的各条边;用克鲁斯卡尔算法得到的最小生成树为:(1,2)3,(4,6)4,(1,3)5,(1,4)8,(2,5)10,(4,7)204.画出向小根堆中加入数据4, 2, 5, 8, 3 时,每加入一个数据后堆的变化;见图12244222图12524445458832354.图11四,阅读算法(每题7 分,共14 分)1. LinkList mynote(LinkList L){//L 是不带头结点的单链表的头指针if(L&&L->next){q=L ;L=L ->next ;p=L ;S1:S2:while(p ->next) p=p ->next ;p->next=q ;q->next=NULL ;}return L;}请回答以下问题:(1)说明语句S1 的功能;查询链表的尾结点(2)说明语句组S2 的功能;将第一个结点链接到链表的尾部,作为新的尾结点,a n),写出算法执行后的返回值所表示的线性(3)设链表表示的线性表为(a1,a2,表;返回的线性表为(a2,a3, ,a n,a1)2. void ABC(BTNode * BT){if BT {ABC (BT->left);ABC (BT->right);cout<<BT->data<<' ';}}该算法的功能是:递归地后序遍历链式储备的二叉树五,算法填空(共二叉搜寻树的查找8 分)——递归算法:bool Find(BTreeNode* BST,ElemType& item) {if (BST==NULL)查找失败return false; //else {if (item==BST->data){item=BST->data;//returnelse if(item<BST->data) return Find(查找胜利;}trueBST->left _ _,item);else return Find( _BST->right ,item);}//if}六,编写算法(共8 分)统计出单链表HL 中结点的值等于给定值X 的结点数;int CountX(LNode* HL,ElemType x)int CountX(LNode* HL,ElemType x)int i=0; LNode* p=HL;//i 为计数器{while(p.=NULL){ if (P->data==x) i++;p=p->next;}//while, 出循环时i 中的值即为x 结点个数return i;}//CountX数据结构试卷(二)一,挑选题(24 分)1.下面关于线性表的表达错误选项();(A) 线性表采纳次序储备必需占用一片连续的储备空间(B) 线性表采纳链式储备不必占用一片连续的储备空间(C) 线性表采纳链式储备便于插入和删除操作的实现(D) 线性表采纳次序储备便于插入和删除操作的实现2.设哈夫曼树中的叶子结点总数为m,如用二叉链表作为储备结构,就该哈夫曼树中总共有()个空指针域;(A) 2m-1 3.设次序循环队列(B) 2m (C) 2m+1 (D) 4mF 和R,头指针F 总是指向队头元素Q[0 :M-1] 的头指针和尾指针分别为的前一位置,尾指针R 总是指向队尾元素的当前位置,就该循环队列中的元素个数为();(C) (R-F+M) %M ABCD ,前序遍历序列为(D) (F-R+M) %MCABD ,就后序遍历该二叉树(A) R-F (B) F-R 4.设某棵二叉树的中序遍历序列为得到序列为((A) BADC );(B) BCDA (C) CDAB (D) CBDA)条边;(D) n -15.设某完全无向图中有(A) n(n-1)/26.设某棵二叉树中有(A) 9n 个顶点,就该完全无向图中有(22 (B) n(n-1) (C) n2000 个结点,就该二叉树的最小高度为();(B) 10 (C) 11 (D) 127.设某有向图中有(A) n-1 n 个顶点,就该有向图对应的邻接表中有()个表头结点;(D) 2n-1(B) n (C) n+18.设一组初始记录关键字序列(5 ,2,6,3,8) ,以第一个记录关键字 5 为基准进行一趟快速排序的结果为((A) 2 ,3,5,8,6(C) 3 ,2,5,6,8 三,应用题(36 分) );(B) 3 ,2,5,8,6(D) 2 ,3,6,5,81.设一组初始记录关键字序列为(45 ,80,48,40,22,78) ,就分别给出第 4 趟简洁挑选排序和第 4 趟直接插入排序后的结果;(22 ,40,45,48,80,78) ,(40 ,45,48,80,22,78)2.设指针变量p 指向双向链表中结点A,指针变量q 指向被插入结点B,要求给出在结点 Allink和rlink);的后面插入结点B的操作序列(设双向链表中结点的两个指针域分别为q->llink=p; q->rlink=p->rlink; p->rlink->llink=q; p->rlink=q;3.设一组有序的记录关键字序列为二分查找,要求运算出查找关键字度;2,ASL=91*1+2*2+3*4+4*2)=25/9 (13 ,18,24,35,47,50,62,83,90) ,查找方法用62 时的比较次数并运算出查找胜利时的平均查找长4.设一棵树T 中边的集合为{(A ,B),(A ,C) ,(A ,D) ,(B ,E),(C,F),(C,G)} ,要求用孩子兄弟表示法(二叉链表)表示出该树的储备结构并将该树转化成对应的二叉树;树的链式储备结构略,二叉树略5.设有无向图G,要求给出用普里姆算法构造最小生成树所走过的边的集合;E={(1 ,3),(1,2),(3,5),(5,6),(6,4)}6.设有一组初始记录关键字为(45 ,80,48,40,22,78) ,要求构造一棵二叉排序树并给出构造过程;四,算法设计题(16 分)1.设有一组初始记录关键字序列(K1,K2,,K n),要求设计一个算法能够在O(n) 的时间复杂度内将线性表划分成两部分,其中左半部分的每个关键字均小于K i ,右半部分的每个关键字均大于等于K i ;设有一组初始记录关键字序列(K1,K2,,K n),要求设计一个算法能够在O(n) 的时间复杂度内将线性表划分成两部分,其中左半部分的每个关键字均小于K i ,右半部分的每个关键字均大于等于K i;void quickpass(int r[], int s, int t){int i=s, j=t, x=r[s];while(i<j){while (i<j && r[j]>x) j=j-1; if (i<j) {r[i]=r[j];i=i+1;}while (i<j && r[i]<x) i=i+1; if (i<j) {r[j]=r[i];j=j-1;}}r[i]=x;}2.设有两个集合 A 和集合B,要求设计生成集合C=A∩B 的算法,其中集合A,B 和C用链式储备结构表示;设有两个集合A 和集合B,要求设计生成集合C=A∩B 的算法,其中集合A,B 和C 用链式存储结构表示;typedef struct node {int data; struct node *next;}lklist;void intersection(lklist *ha,lklist *hb,lklist *&hc){lklist *p,*q,*t;for(p=ha,hc=0;p.=0;p=p->next){for(q=hb;q.=0;q=q->next) if (q->data==p->data) break;if(q.=0){ t=(lklist *)malloc(sizeof(lklist)); t->data=p->data;t->next=hc; hc=t;} }}数据结构试卷(三)一,挑选题 ( 每题 1 分,共 20 分 ) 1.设某数据结构的二元组形式表示为A=(D , R), D={01 , 02, 03, 04, 05, 06, 07, 08,09} , R={r} , r={<01 , 02>, <01 , 03>, <01 ,04>, <02, 05>,<02 , 06>, <03 , 07>, <03 ,08>, <03, 09>} ,就数据结构 A 是( ); (A) 线性结构 树型结构 )(C) 物理结构 (D) 图型结构(B) 2.下面程序的时间复杂为(for ( i=1 , s=0; i<=n ; i++ ) {t=1 ; for(j=1 ; j<=i ; j++) t=t*j ; s=s+t ;}234(A) O( n) 3.设指针变量 (B) O(n )p 指向单链表中结点 (C) O(n )A ,如删除单链表中结点(D) O(n )A ,就需要修改指针的操作序列为();(A ) q=p->next; p->data=q->data (B ) q=p->next ; q->data=p->data (C ) q=p->next ; p->next=q->next (D ) q=p->next ; p->data=q->data ; p->next=q->next ; p->next=q->next ; free(q) ;; free(q) ; ; free(q) ; free(q) ; ; 4.设有 n 个待排序的记录关键字,就在堆排序中需要()个帮助记录单元; 2(A) 1(B) n(C) nlog 2n (D) n5.设一组初始关键字记录关键字为录的一趟快速排序终止后的结果为(20 ,15,14,18, 21, 36,40,10) ,就以 20 为基准记( ) ;(A) 10 , 15, 14, 18,20, 36, 40, 21 (B) 10 , 15, 14, 18, 20, 40, 36, 21 (C) 10 , 15, 14, 20, 18, 40, 36, 2l (D) 15 , 10, 14, 18, 20, 36, 40, 216.设二叉排序树中有 (A) O(1) n 个结点,就在二叉排序树的平均平均查找长度为();2(B) O(log2n) (C) (D) O(n )7.设无向图 G 中有个顶点 e 条边,就其对应的邻接表中的表头结点和表结点的个数分别 n 为( ); (A) n , e 8. 设某强连通图中有 (A) n(n-1) (B) e , n (C) 2n , e (D) n ,2e )条边; (D) n(n+1)n 个顶点,就该强连通图中至少有((B) n+1(C) n9.设有 5000 个待排序的记录关键字,假如需要用最快的方法选出其中最小的10 个记录关键字,就用以下( (A) 快速排序 10. 以下四种排序中((A) 插入排序)方法可以达到此目的; (B) 堆排序 (C) 归并排序 插入排序 (D) )的空间复杂度最大;(B) 冒泡排序堆排序归并排序(C) (D) 三,运算题 ( 每题 分,共 30 分 )10 1.已知二叉树的前序遍历序列是 AEFBGCDHIKJ ,中序遍历序列是 EFAGBCHKIJD ,画出此二叉树,并画出它的后序线索二叉树;ABECGFNULLDHF KJ2.已知待散列的线性表为( 36, 15, 40, 63, 22),散列用的一维地址空间为[0 ..6],假定选用的散列函数是 H ( K ) = K mod 7 ,如发生冲突采纳线性探查法处理,试:.冲突H(36)=36 mod 7=1;H(15)=15 mod 7=1; H 1 (22)=(1+1) mod 7=2;.冲突 H 2 (22)=(2+1) mod 7=3;H 1 (15)=(1+1) mod 7=2;H(40)=40 mod 7=5; H(63)=63 mod 7=0; .冲突H(22)=22 mod 7=1;( 1)运算出每一个元素的散列地址并在下图中填写出散列表: `0 1234 405663361522( 2)求出在查找每一个元素概率相等情形下的平均查找长度; 1 2 1 51 3ASL=3.已知序列( 10,18, 4, 3, 6,12,1,9,18,8)请用快速排序写出每一趟排序的结果;(8,9,4,3,6,1),10,(12,18,18) (1,6,4,3),8,(9),10,12,(18,18) 1,(3,4,6),8,9,10,12,18,(18) 1,3,(4,6),8,9,10,12,18,18 1,3, 4,6,8,9,10,12,18,18四,算法设计题 ( 每题 15 分,共 30 分 )1. 设计在单链表中删除值相同的余外结点的算法;设计在单链表中删除值相同的余外结点的算法;typedef int datatype;typedef struct node {datatype data; struct node *next;}lklist; void delredundant(lklist *&head) {lklist *p,*q,*s;for(p=head;p.=0;p=p->next) {for(q=p->next,s=q;q.=0; )if (q->data==p->data) {s->next=q->next; free(q);q=s->next;} else {s=q,q=q->next;}}}2.设计一个求结点设计一个求结点x 在二叉树中的双亲结点算法;x 在二叉树中的双亲结点算法;typedef struct node {datatype data; struct node *lchild,*rchild;} bitree;bitree *q[20]; int r=0,f=0,flag=0;void preorder(bitree *bt, char x){if (bt.=0 && flag==0)if (bt->data==x) { flag=1; return;}else {r=(r+1)% 20; q[r]=bt; preorder(bt->lchild,x); preorder(bt->rchild,x); } }void parent(bitree *bt,char x){int i;preorder(bt,x);for(i=f+1; i<=r; i++) if (q[i]->lchild->data==x || q[i]->rchild->data) break;if (flag==0) printf("not found x\n");else if (i<=r) printf("%c",bt->data); else printf("not parent");}数据结构试卷(四)一,挑选题 ( 每题 1 分共 20 分 )1.设一维数组中有 (A) O(n)n 个数组元素,就读取第i 个数组元素的平均时间复杂度为();2(B) O(nlog2n) (C) O(1)(D) O(n ) )个结点;(D) 2 -12.设一棵二叉树的深度为 k ,就该二叉树中最多有(kk-1k(A) 2k-1 3.设某无向图中有 (A) n (B) 2 (C) 2 n 个顶点 e 条边,就该无向图中全部顶点的入度之和为();(B) e (C) 2n(D) 2e4.在二叉排序树中插入一个结点的时间复杂度为( );2n)2(A) O(1) (B) O(n)(C) O(log (D) O(n )5.设某有向图的邻接表中有n 个表头结点和 m 个表结点,就该图中有()条有向边;(A) n(B) n-1 (C) m (D) m-16.设一组初始记录关键字序列为(345 ,253,674,924,627) ,就用基数排序需要进行 ( )趟的安排和回收才能使得初始关键字序列变成有序序列;(A) 3(B) 4(C) 5(D) 87.设用链表作为栈的储备结构就退栈操作((A) 必需判别栈是否为满(C) 判别栈元素的类型 ); (B) 必需判别栈是否为空 (D) 对栈不作任何判别8.以下四种排序中((A) 快速排序9.设某二叉树中度数为 )的空间复杂度最大;(B) 冒泡排序0 的结点数为 (C) 希尔排序堆N l ,度数为 2 的结点数为 (D) N 0,度数为 1 的结点数为 N 2,就以下等式成立的是( );(A) N 0=N 1+1 10. 设有序次序表中有 (B) N 0=N l +N 2(C) N 0=N 2+1(D) N 0=2N 1+ln 个数据元素,就利用二分查找法查找数据元素X 的最多比较次数不超过( (A) log); 2n+1(B) log2n-1 (C) log 2n (D) log 2(n+1)三,运算题 ( 每题 分,共 30 分 ) 10 1,画出广义表 的头尾链表储备结构;LS=(( ) , (e) , (a , (b , c , d ))) 1 1----> 1LS1^ ^----> 1 ----> 11^ ^ 0 0 ea1----> ----> 1 1 ^ b0 0 cd0 2,下图所示的森林:(1) 求树( a )的先根序列和后根序列; BDEFCA ; (2) ABCDEFGHIJK;林转换为相应的二叉树;(1) ABCDEF;BDEFCAIJKHGAGBC HIDJEF K(2) 求森林先序序列和中序序列; BDEFCA ;ABCDEF;( 3)将此森林转换为相应的二叉树;A GBC H FD EIJ (b)K(a)(2) ABCDEFGHIJK;BDEFCAIJKHG 林转换为相应的二叉树;AGBC HIDJEF K23,设散列表的地址范畴是 表处理冲突,请画出元素 ,散列函数为 H ( key ) = ( key +2) MOD 9,并采纳链 [ 0..9 ] 7, 4, 5, 3, 6, 2,8, 9 依次插入散列表的储备结构; H(4)=H(5)=0,H(3)=H(6)=H(9)=2,H(8)=3,H(2)=H(7)=6540 ^1 2 3 4 5 6 7 89 ^63 89^^ ^7^2^ ^ ^四,算法设计题( 每题10 分,共30 分)1.设单链表中有仅三类字符的数据元素( 大写字母,数字和其它字符) ,要求利用原单链表中结点空间设计出三个单链表的算法,使每个单链表只包含同类字符;设单链表中有仅三类字符的数据元素( 大写字母,数字和其它字符) ,要求利用原单链表中结点空间设计出三个单链表的算法,使每个单链表只包含同类字符;typedef char datatype;typedef struct node {datatype data; struct node *next;}lklist;void split(lklist *head,lklist *&ha,lklist *&hb,lklist *&hc){lklist *p; ha=0,hb=0,hc=0;for(p=head;p.=0;p=head){head=p->next; p->next=0;if (p->data>='A' && p->data<='Z') {p->next=ha; ha=p;}else if (p->data>='0' && p->data<='9') {p->next=hb; hb=p;} else {p->next=hc; hc=p;}}}设计在链式储备结构上交换二叉树中全部结点左右子树的算法;2.设计在链式储备结构上交换二叉树中全部结点左右子树的算法;typedef struct node {int data; struct node *lchild,*rchild;} bitree;void swapbitree(bitree *bt){bitree *p;if(bt==0) return;swapbitree(bt->lchild); swapbitree(bt->rchild);p=bt->lchild; bt->lchild=bt->rchild; bt->rchild=p;}在链式储备结构上建立一棵二叉排序树;3.在链式储备结构上建立一棵二叉排序树;#define n 10typedef struct node{int key; struct node *lchild,*rchild;}bitree;void bstinsert(bitree *&bt,int key){if (bt==0){bt=(bitree *)malloc(sizeof(bitree)); bt->key=key;bt->lchild=bt->rchild=0;}else if (bt->key>key) bstinsert(bt->lchild,key); else bstinsert(bt->rchild,key);}void createbsttree(bitree *&bt){int i;for(i=1;i<=n;i++) bstinsert(bt,random(100));}数据结构试卷(五)一,挑选题 (20 分 ) 1.数据的最小单位是((A) 数据项); (B) 数据类型(C) 数据元素(D) 数据变量2.设一组初始记录关键字序列为(50 , 40, 95, 20, 15, 70, 60, 45) ,就以增量 d=4 的一趟希尔排序终止后前 (A) 40 , 50, 20, 95 (C) 15 , 20, 40, 454 条记录关键字为( (B) 15 (D) 45 );, 40, 60, 20 ,40, 15, 20 3.设一组初始记录关键字序列为 (25, 50, 15,35,80, 85,20,40,36,70),其中含有 5 个长度为 果为(2 的有序子表,就用归并排序的方法对该记录关键字序列进行一趟归并后的结);(A) 15 ,25, 35 , 50, 20, 40, 80, 85, 36, 70 (B) 15 ,25, 35,50, 80,20, 85, 40, 70, 36 (C) 15 ,25, 35,50, 80,85, 20, 36, 40, 70 (D) 15 ,25, 35,50, 80,20, 36,40, 70,85 4.函数 substr( “DATASTRUCT U ”R E , 5, 9) 的返回值为();(A) “STRUCTUR ”E (C) “ASTRUCTU ”R 5.设一个有序的单链表中有就该操作的时间复杂度为(“ DATA ”(B) (D) “ DATASTRUCT U ”REn 个结点, 现要求插入一个新结点后使得单链表仍旧保持有序,);2(A) O(log2n)(B) O(1) (C) O(n )(D) O(n)6.设一棵 m 叉树中度数为 点数为 Nm ,就 N =( 0 的结点数为 );N 0,度数为 1 的结点数为 N l , ,度数为 m 的结 (A) N l +N 2+ +Nm (B) l+N 2+2N 3+3N 4++(m-1)Nm (C) N 2+2N 3+3N 4+ +(m-1)Nm (D) 2N l +3N2+ +(m+1)NmX 最多需要比较((D) 17.设有序表中有 (A) 251000 个元素,就用二分查找查找元素)次;(B) 10(C) 78.设连通图 G 中的边集 E={(a ,b),(a , e),(a , c),(b , e),(e , d),(d , f), (f ,c)} ,就从顶点 a 动身可以得到一种深度优先遍历的顶点序列为( );(A) abedfc9.设输入序列是 (B) acfebd(C) aebdfc(D) aedfcb1, 2,3,, n ,经过栈的作用后输出序列的第一个元素是 );n ,就输出序列中第 (A) n-ii 个输出元素是( (B) n-1-i(D) 不能确定(C) n+1-i10 设一组初始记录关键字序列为(45 , 80, 55, 40,42, 85) ,就以第一个记录关键字45为基准而得到一趟快速排序的结果是( (A) 40 , 42, 45, 55, 80, 83 (C) 42 , 40, 45,55, 80, 85 );(B) 42 , 40, 45, 80, 85, 88 (D) 42 , 40, 45, 85, 55, 80三,应用题 (32 分 ) 1.设某棵二叉树的中序遍历序列为DBEAC ,前序遍历序列为 ABDEC ,要求给出该二叉树的的后序遍历序列; DEBCA2. 设无向图G(如右图所示),给出该图的最小生成树上边的集合并运算最小生成树各边上的权值之和;E={(1,5),(5,2),(5,3),(3,4)},W=103. 设一组初始记录关键字序列为(15 ,17,18,22,35,51,60) ,要求运算出胜利查找时的平均查找长度;ASL=(1*1+2*2+3*4)/7=17/74. 设散列表的长度为8,散列函数H(k)=k mod7,初始记录关键字序列为(25 ,31,8,27,13,68) ,要求分别运算出用线性探测法和链地址法作为解决冲突方法的平均查找长度;ASL1=7/6 ,ASL2=4/3四,算法设计题(28 分)1.设计判定两个二叉树是否相同的算法;设计判定两个二叉树是否相同的算法;typedef struct node {datatype data; struct node *lchild,*rchild;} bitree;int judgebitree(bitree *bt1,bitree *bt2){if (bt1==0 && bt2==0) return(1);else if (bt1==0 || bt2==0 ||bt1->data.=bt2->data) return(0);else return(judgebitree(bt1->lchild,bt2->lchild)*judgebitree(bt1->rchild,bt2->rchild));}2.设计两个有序单链表的合并排序算法;设计两个有序单链表的合并排序算法;void mergelklist(lklist *ha,lklist *hb,lklist *&hc){lklist *s=hc=0;while(ha.=0 && hb.=0)if(ha->data<hb->data){if(s==0) hc=s=ha; else {s->next=ha; s=ha;};ha=ha->next;}else {if(s==0) hc=s=hb; else {s->next=hb; s=hb;};hb=hb->next;}if(ha==0) s->next=hb; else s->next=ha;}数据结构试卷(六)一,挑选题 (30 分 )1. 设一组权值集合 W={2, 3, 4,5,6} ,就由该权值集合构造的哈夫曼树中带权路径长度之和为( (A) 20);(B) 30(C) 40); ,63] (D) 452.执行一趟快速排序能够得到的序列是((A) [41 ,12, 34, 45,27] 55 [72 (B) [45 , 34, 12, 41] 55 [72 ,63, 27] (C) [63 , 12, 34, 45, 27] 55 [41 , 72] (D) [12 , 27, 45, 41] 55 [34 3.设一条单链表的头指针变量为(A) head==0(C) head->next==head,63, 72] head 且该链表没有头结点,就其判空条件是((B) head->next==0 (D) head.=0 );4.时间复杂度不受数据初始状态影响而恒为O(nlog 2n) 的是( ); 快速排序(A) 堆排序(B) 冒泡排序(C) 希尔排序(D) 5.设二叉树的先序遍历序列和后序遍历序列正好相反,就该二叉树满意的条件是(); (A) 空或只有一个结点 (C) 任一结点无左孩子 高度等于其结点数 任一结点无右孩子(B) (D) 6.一趟排序终止后不肯定能够选出一个元素放在其最终位置上的是();希尔排序); (A) 堆排序 7.设某棵三叉树中有 (A) 3 (B) 冒泡排序 (C) 快速排序 (D) 40 个结点,就该三叉树的最小高度为((B) 4 (C) 5 (D) 68.次序查找不论在次序线性表中仍是在链式线性表中的时间复杂度为();21/2(A) O(n) (B) O(n ) (C) O(n ) (D) O(1og 2n) 9.二路归并排序的时间复杂度为( );2 (A) O(n) 深度为 (B) O(n ) k 的完全二叉树中最少有((C) O(nlog )个结点; (C) 2+12n)(D) O(1og 2n) 10. k-1k-1k-1k(A) 2-1设指针变量 (B) 2(D) 2 -1rear 表示链式队列的队尾指针,front 表示链式队列的队头指针,指针变量11. 指针变量 s 指向将要入队列的结点 X ,就入队列的操作序列为();; front=s ;rear=s ; ;; rear=s ;; front=s ; (A) front->next=s(C) rear->next=s 设某无向图中有 (A) O(n+e) 设某哈夫曼树中有 (A) 99 设二叉排序树上有 (A) O(n)(B) s->next=rear(D) s->next=frontn 个顶点 e 条边,就建立该图邻接表的时间复杂度为();12. 23(B) O(n ) (C) O(ne) (D) O(n ) )个叶子结点; (D) 102199 个结点,就该哈夫曼树中有(13. (B) 100 (C) 101 n 个结点,就在二叉排序树上查找结点的平均时间复杂度为(); 14. 2 (B) O(n )(C) O(nlog2n)(D) O(1og 2 n)设用邻接矩阵 A 表示有向图 G 的储备结构,就有向图 G 中顶点 i 的入度为();15. (A) 第 (C) 第 i 行非 0 元素的个数之和 第 第 i 列非 0 元素的个数之和i 列 0 元素的个数之和(B) (D) i 行 0 元素的个数之和 四,算法设计题 (20 分 )1.设计在次序有序表中实现二分查找的算法;设计在次序有序表中实现二分查找的算法;struct record {int key; int others;};int bisearch(struct record r[ ], int k){int low=0,mid,high=n-1;while(low<=high){mid=(low+high)/2;return(mid+1);else if(r[mid].key>k)high=mid-1;else if(r[mid].key==k)low=mid+1;}return(0);}2.设计判定二叉树是否为二叉排序树的算法;设计判定二叉树是否为二叉排序树的算法;int minnum=-32768,flag=1;typedef struct node{int key; struct node *lchild,*rchild;}bitree;void inorder(bitree *bt){if(bt.=0){inorder(bt->lchild);if(minnum>bt->key)flag=0; minnum=bt->key;inorder(bt->rchild);}}3.在链式储备结构上设计直接插入排序算法在链式储备结构上设计直接插入排序算法void straightinsertsort(lklist *&head){lklist *s,*p,*q;int t;if (head==0 || head->next==0) return;else for(q=head,p=head->next;p.=0;p=q->next){for(s=head;s.=q->next;s=s->next) if (s->data>p->data) break;if(s==q->next)q=p;p->next=s->next;s->next=p;else{q->next=p->next;t=p->data;p->data=s->data;s->data=t;}}}数据结构试卷(七)一,挑选题 (30 分 )1.设某无向图有 (A) 2nn 个顶点,就该无向图的邻接表中有()个表头结点; (D) n(n-1))条边; (D) 2n-1(B) n(C) n/22.设无向图 (A) n G 中有 n 个顶点,就该无向图的最小生成树上有((B) n-1 (C) 2n 3.设一组初始记录关键字序列为而得到的一趟快速排序结果是( (60 ,80,55,40,42, 85) ,就以第一个关键字 );45 为基准(A) 40 , 42, 60, 55, 80, 85(C) 42 , 40, 55, 60, 80, 85 (B) 42 , 45, 55, 60, 85, 80(D) 42 , 40, 60, 85, 55, 80 4.( )二叉排序树可以得到一个从小到大的有序序列; (A) 先序遍历(B) 中序遍历(C) 后序遍历(D) 层次遍历5.设依据从上到下,从左到右的次序从1 开头对完全二叉树进行次序编号,就编号为i 结点的左孩子结点的编号为( );(A) 2i+1 (B) 2i (C) i/2(D) 2i-16.程序段 s=i=0; do {i=i+1 ; s=s+i ; }while(i<=n) ;的时间复杂度为();23(A) O(n) (B) O(nlog2n)(C) O(n ) (D) O(n /2)7.设带有头结点的单向循环链表的头指针变量为 head ,就其判空条件是();(A) head==0(C) head->next==head 8.设某棵二叉树的高度为(B) head->next==0 (D) head.=0 10,就该二叉树上叶子结点最多有();(A) 20(B) 256 (C) 512(D) 1024 9.设一组初始记录关键字序列为 (13 ,18,24,35,47,50, 62, 83, 90,115, 134), 就利用二分法查找关键字 90 需要比较的关键字个数为();(D) 4(A) 1 10. 设指针变量 (B) 2 (C) 3 top 指向当前链式栈的栈顶,就删除栈顶元素的操作序列为();(A) top=top+1; (C) top->next=top; (B) top=top-1; (D) top=top->next;四,算法设计题 (20 分 ) 1.设计在链式结构上实现简洁挑选排序算法; 设计在链式结构上实现简洁挑选排序算法;void simpleselectsorlklist(lklist *&head) {lklist *p,*q,*s;int min,t;if(head==0 ||head->next==0) return; for(q=head; q.=0;q=q->next) {min=q->data; s=q;for(p=q->next; p.=0;p=p->next) if(min>p->data){min=p->data; s=p;} if(s.=q){t=s->data; s->data=q->data; q->data=t;} } }2. 设计在次序储备结构上实现求子串算法;设计在次序储备结构上实现求子串算法;void substring(char s[ ], long start, long count, char t[ ]){long i,j,length=strlen(s);if (start<1 || start>length) printf("The copy position is wrong");else if (start+count-1>length) printf("Too characters to be copied");else { for(i=start-1,j=0; i<start+count-1;i++,j++) t[j]=s[i]; t[j]= '\0';}}3. 设计求结点在二叉排序树中层次的算法;设计求结点在二叉排序树中层次的算法;int lev=0;typedef struct node{int key; struct node *lchild,*rchild;}bitree;void level(bitree *bt,int x){if (bt.=0){lev++;if(bt->key==x)return;else if(bt->key>x)level(bt->lchild,x);else level(bt->rchild,x);}}数据结构试卷(八)一,挑选题 (30 分 ) 字符串的长度是指( (A) 串中不同字符的个数 (C) 串中所含字符的个数 );1.串中不同字母的个数 串中不同数字的个数(B) (D) 建立一个长度为 (A) O(n)n 的有序单链表的时间复杂度为( )2. 2(B) O(1)(C) O(n ) );(D) O(log 2n)两个字符串相等的充要条件是( (A) 两个字符串的长度相等 (C) 同时具备 (A) 和 (B) 两个条件3.两个字符串中对应位置上的字符相等 以上答案都不对(B) (D) 设某散列表的长度为 (A) 99 100,散列函数 (B) 97 H(k)=k % P ,就 (C) 91 P 通常情形下最好挑选( (D) 93); (D) O(n ));4. 在二叉排序树中插入一个关键字值的平均时间复杂度为(5. 2(A) O(n)设一个次序有序表 (B) O(1og 2n)A[1:14] 中有 ; (C) O(nlog2n)14 个元素,就采纳二分法查找元素A[4] 的过程中比较6.元素的次序为 ( (A) A[1] , A[2] (C) A[7] , A[3] ) , A[3] , A[5] ,A[4] ,A[4], A[14] , A[7] ,A[4] , A[4] ); (B) A[1] (D) A[7] ,A[5] , A[3] 设一棵完全二叉树中有 65 个结点,就该完全二叉树的深度为(7. (A) 8设一棵三叉树中有 就该三叉链权中有( (B) 72 个度数为 (C) 61 的结点,2 个度数为 (D) 52 的结点, 2 个度数为3 的结点, 8.)个度数为 0 的结点;(C) 7(A) 5设无向图 就从顶点 (A) aedfcb(B) 6G 中的边的集合 (D) 8E={(a , b), (a , e), (a ,c) , (b , e), (e , d),(d ,f) ,(f ,c)} ,9.a 动身进行深度优先遍历可以得到的一种顶点序列为( ); (B) acfebd )的线性表; (B) 先进后出(C) aebcfd(D) aedfbc队列是一种((A) 先进先出10. (C) 只能插入(D) 只能删除四,算法设计题 分 ) (20 1.设计一个在链式储备结构上统计二叉树中结点个数的算法; 设计一个在链式储备结构上统计二叉树中结点个数的算法;void countnode(bitree *bt,int &count) {if(bt.=0){count++; countnode(bt->lchild,count); countnode(bt->rchild,count);}} 2.设计一个算法将无向图的邻接矩阵转为对应邻接表的算法; 设计一个算法将无向图的邻接矩阵转为对应邻接表的算法;typedef struct {int vertex[m]; int edge[m][m];}gadjmatrix;typedef struct node1{int info;int adjvertex; struct node1 *nextarc;}glinklistnode; typedef struct node2{int vertexinfo;glinklistnode *firstarc;}glinkheadnode; void adjmatrixtoadjlist(gadjmatrix g1[ ],glinkheadnode g2[ ]) {int i,j; glinklistnode *p;for(i=0;i<=n-1;i++) g2[i].firstarc=0;for(i=0;i<=n-1;i++) for(j=0;j<=n-1;j++)if (g1.edge[i][j]==1){p=(glinklistnode *)malloc(sizeof(glinklistnode));p->adjvertex=j;p->nextarc=g[i].firstarc; g[i].firstarc=p;p=(glinklistnode *)malloc(sizeof(glinklistnode));p->adjvertex=i;p->nextarc=g[j].firstarc; g[j].firstarc=p;}}数据结构试卷(九)一,挑选题 (30 分 )1.以下程序段的时间复杂度为();for(i=0 ; i<m ; i++) for(j=0 ; j<t ; j++) c[i][j]=0 ;for(i=0 ; i<m ; (A) O(m*n*t) i++) for(j=0 ; j<t ; j++) for(k=0 ; k<n ; k++) c[i][j]=c[i][j]+a[i][k]*b[k][j] ;(B) O(m+n+t) (C) O(m+n*t) (D) O(m*t+n)2.设次序线性表中有 (A) n-in 个数据元素,就删除表中第i 个元素需要移动((D) i)个元素;(B) n+l -i(C) n-1-i3.设 F 是由 数分别为 (A) N1-1 T1,T2 和 T3 三棵树组成的森林,与 F 对应的二叉树为 B ,T1,T2 和 T3 的结点N1, N2 和 N3,就二叉树 (B) N2-1 B 的根结点的左子树的结点数为(); (C) N2+N3(D) N1+N34.利用直接插入排序法的思想建立一个有序线性表的时间复杂度为();2n)X ,就在结点 A 的后 2(A) O(n)5.设指针变量 面插入结点 (B) O(nlog2n)(C) O(n ) A ,指针变量 (D) O(1og s 指向被插入的结点 p 指向双向链表中结点 X 的操作序列为( );(A) p->right=s ; s->left=p ; p->right->left=s ; s->right=p->right ;p->right->left=s ; s->right=p->right ;(B ) s->left=p ; s->right=p->right ; p->right=s ; (C )p->right=s ; p->right->left=s ; s->left=p ; (D) s->left=p ; s->right=p->right ; p->right->left=s ; p->right=s ;); (D) 冒泡排序26.以下各种排序算法中平均时间复杂度为O(n ) 是( (C) 归并排序(A) 快速排序堆排序(B) 7.设输入序列 1, 2,3, ,n 经过栈作用后,输出序列中的第一个元素是 ); n ,就输出序列中的第 (A) n-ii 个输出元素是( (D) 不能确定(B) n-1-im 个储备单元,散列函数 m 的最大奇数 m 的最大偶数(C) n+l -i8.设散列表中有 (A) 小于等于 (C) 小于等于 9.设在一棵度数为 H(key)= key % p ,就 p 最好挑选((B) 小于等于 m 的最大素数(D) 小于等于 m 的最大合数);3 的树中,度数为 2 个,那么度数为 (B) 53 的结点数有 0 的结点数有( (C) 62 个,度数为 )个;(D) 7 2 的结点数有 1 个,度数为 1 的结点数有 (A) 410. 设完全无向图中有 (A) n(n-1)/2 11. 设次序表的长度为 (A) nn 个顶点,就该完全无向图中有( )条边; (D) (n-1)/2); (D) (n-1)/2(B) n(n-1) (C) n(n+1)/2 n ,就次序查找的平均比较次数为( (B) n/2 (C) (n+1)/212. 设有序表中的元素为 的元素需要经过( (A) 1 (13 , 18,24,35,47,50,62) ,就在其中利用二分法查找值为 )次比较; 24(B) 2(C) 35 块,每块 (D) 46 个元素,假如采纳分块查找,就其平均查13. 设次序线性表的长度为30,分成 找长度为( (A) 614. 设有向无环图 );(B) 11G 中的有向边集合 (C) 5 (D)E={<1 , 2>, <2, 3>, <3, 4> , <1, 4>} ,就以下属于 该有向图 G 的一种拓扑排序序列的是();(C) 1 , 4, 2, 3 (A) 1 , 2, 3, 4 (B) 2 , 3, 4,1(D) 1 , 2, 4, 315. 设有一组初始记录关键字序列为生成的二叉排序树的深度为((34 ,76,45,18,26,54,92) ,就由这组记录关键字);(A) 4五,算法设计题(B) 5(20 分)(C) 6 (D) 71.设计运算二叉树中全部结点值之和的算法;设计运算二叉树中全部结点值之和的算法;void sum(bitree *bt,int &s){if(bt.=0) {s=s+bt->data; sum(bt->lchild,s); sum(bt->rchild,s);} }2.设计将全部奇数移到全部偶数之前的算法;设计将全部奇数移到全部偶数之前的算法;void quickpass(int r[], int s, int t){int i=s,j=t,x=r[s];while(i<j){while (i<j && r[j]%2==0) j=j-1; while (i<j && r[i]%2==1) i=i+1;if (i<j) {r[i]=r[j];i=i+1;} if (i<j) {r[j]=r[i];j=j-1;}}r[i]=x;}3.设计判定单链表中元素是否是递增的算法;设计判定单链表中元素是否是递增的算法;int isriselk(lklist *head){if(head==0||head->next==0) return(1);elsefor(q=head,p=head->next; p.=0; q=p,p=p->next)if(q->data>p->data) return(0);return(1);}数据结构试卷(十)一,挑选题 (24 分 )1.以下程序段的时间复杂度为();i=0 , s=0; (A) O(n)while (s<n) {s=s+i ; i++ ; }1/21/32(B) O(n)(C) O(n)(D) O(n )2.设某链表中最常用的操作是在链表的尾部插入或删除元素,就选用以下(最节约运算时间;)储备方式(A) 单向链表 (C) 双向链表3.设指针 q 指向单链表中结点 单向循环链表 双向循环链表(B) (D) A ,指针 p 指向单链表中结点 A 的后继结点 B ,指针 s 指向被插入的结点 X ,就在结点 A 和结点 B 插入结点 X 的操作序列为( );; p->next=-s ; ; s->next=p ;; s->next=q ;(A) s->next=p->next (C) p->next=s->next(B) q->next=s(D) p->next=s ; s->next=p ; 4.设输入序列为 1, 2, 3,4, 5, 6,就通过栈的作用后可以得到的输出序列为();(A) 5 , 3, 4, 6,1, 2 (C) 3 , 1, 2, 5,4, 6(B) 3 ,2, 5, 6, 4,1 (D) 1 , 5, 4, 6, 2, 3A (包括对角线),依据从上到下,从左到右的次序储备到 5.设有一个 10 阶的下三角矩阵 连续的 55 个储备单元中, 每个数组元素占 1 个字节的储备空间, 就 A[5][4] 地址与 A[0][0] 的地址之差为( (A) 106.设一棵 m 叉树中有 ); (B) 19(C) 28(D) 552 的结点,N 1 个度数为 1 的结点, N 2 个度数为 , Nm 个度数为m的结点,就该树中共有( )个叶子结点;mmmm(A)(C)(D) (i 1) N iN iN i1(i 1) N i(B)i 1i 1i 2i 27. 二叉排序树中左子树上全部结点的值均()根结点的值;(D) .=(A) <8. 设一组权值集合 (B) >(C) =W=(15,3,14, 2, 6,9, 16, 17) ,要求依据这些权值集合构造一棵哈夫曼树,就这棵哈夫曼树的带权路径长度为( );(A) 129 (B) 219 (C) 189(D) 2299. 设有 n 个关键字具有相同的 Hash 函数值,就用线性探测法把这n 个关键字映射到 HASH表中需要做( )次线性探测;(B) n(n+1)2(A) n(C) n(n+1)/2(D) n(n-1)/20 的结点数为 10. 设某棵二叉树中只有度数为0 和度数为 2 的结点且度数为 n ,就这棵二叉中共有( (A) 2n )个结点;(B) n+l (C) 2n-1 8,就最多经过((C) 8(D) 2n+l)趟插入排序可以得到有序序列;(D) 911. 设一组初始记录关键字的长度为 (A) 6(B) 712. 设一组初始记录关键字序列为(Q ,H , C , Y ,P , A ,M , S , R ,D , F , X) ,就按字母升序的第一趟冒泡排序终止后的结果是();(A )F , H ,C ,D , P ,A ,M , Q ,R , S , Y , X(B ) P , A ,C , S , Q ,D ,F , X , R ,H , M , Y (C ) A , D , C , R , F , Q , M , S ,Y , P , H ,X (D)H , C , Q , P ,A , M , S , R , D , F , X , Y。
数据结构习题(包含全部答案解析)数据结构习题(包含全部答案解析)1. 塔的问题题目描述:有三个塔,分别是A、B和C,A塔上有n个盘子,按照从小到大的顺序叠放。
现在要将这些盘子从A塔移动到C塔,并且每次只能移动一个盘子,并且在移动过程中保持大盘子在下,小盘子在上的顺序。
求移动的步骤。
解析:这道题可以使用递归来解决。
将问题分解为两个子问题:将n-1个盘子从A塔移动到B塔,然后将最后一个盘子从A塔移动到C 塔,最后再将n-1个盘子从B塔移动到C塔。
步骤如下:1)如果n等于1,直接将盘子从A塔移动到C塔;2)否则,执行以下步骤:a) 将n-1个盘子从A塔移动到B塔,使用C塔作为中转塔;b) 将最后一个盘子从A塔移动到C塔;c) 将n-1个盘子从B塔移动到C塔,使用A塔作为中转塔。
2. 链表问题题目描述:给定一个链表,判断链表是否存在环。
解析:这道题可以使用快慢指针的思想来解决。
定义两个指针fast和slow,初始时都指向链表的头节点。
fast指针每次向后移动两个节点,slow指针每次向后移动一个节点。
如果链表中存在环,则fast指针一定会在某个时刻追上slow指针。
步骤如下:1)定义两个指针fast和slow,初始时都指向链表的头节点;2)使用一个while循环,判断条件是fast指针不为空且其下一个节点也不为空;3)在循环中,fast指针每次向后移动两个节点,slow指针每次向后移动一个节点;4)如果fast指针和slow指针相遇,则链表存在环,返回true;5)如果fast指针和slow指针永远不相遇,则链表不存在环,返回false。
3. 栈的应用题目描述:给定一个只包含'('和')'的字符串,判断该字符串是否是有效的括号序列。
解析:这道题可以使用栈来解决。
遍历字符串的每一个字符,如果是左括号,将其压入栈中;如果是右括号,判断栈顶的字符是否与该右括号匹配,若匹配则出栈,若不匹配则该字符串不是有效的括号序列。
第1章绪论习题1.简述下列概念:数据、数据元素、数据项、数据对象、数据结构、逻辑结构、存储结构、抽象数据类型。
2.试举一个数据结构的例子,叙述其逻辑结构和存储结构两方面的含义和相互关系。
3.简述逻辑结构的四种基本关系并画出它们的关系图。
4.存储结构由哪两种基本的存储方法实现?5.选择题(1)在数据结构中,从逻辑上可以把数据结构分成()。
A.动态结构和静态结构B.紧凑结构和非紧凑结构C.线性结构和非线性结构D.内部结构和外部结构(2)与数据元素本身的形式、内容、相对位置、个数无关的是数据的()。
A.存储结构B.存储实现C.逻辑结构D.运算实现(3)通常要求同一逻辑结构中的所有数据元素具有相同的特性,这意味着()。
A.数据具有同一特点B.不仅数据元素所包含的数据项的个数要相同,而且对应数据项的类型要一致C.每个数据元素都一样D.数据元素所包含的数据项的个数要相等(4)以下说法正确的是()。
A.数据元素是数据的最小单位B.数据项是数据的基本单位C.数据结构是带有结构的各数据项的集合D.一些表面上很不相同的数据可以有相同的逻辑结构(5)以下与数据的存储结构无关的术语是()。
A.顺序队列 B. 链表 C. 有序表 D. 链栈(6)以下数据结构中,()是非线性数据结构A.树B.字符串C.队D.栈6.试分析下面各程序段的时间复杂度。
(1)x=90; y=100;while(y>0)if(x>100){x=x-10;y--;}else x++;(2)for (i=0; i<n; i++)for (j=0; j<m; j++)a[i][j]=0;(3)s=0;for i=0; i<n; i++)for(j=0; j<n; j++)s+=B[i][j];sum=s;(4)i=1;while(i<=n)i=i*3;(5)x=0;for(i=1; i<n; i++)for (j=1; j<=n-i; j++)x++;(6)x=n; //n>1y=0;while(x≥(y+1)* (y+1))y++;(1)O(1)(2)O(m*n)(3)O(n2)(4)O(log3n)(5)因为x++共执行了n-1+n-2+……+1= n(n-1)/2,所以执行时间为O(n2)(6)O(n)第2章线性表1.选择题(1)一个向量第一个元素的存储地址是100,每个元素的长度为2,则第5个元素的地址是()。
数据结构习题讲解第1章绪论一、判断题1. 数据的逻辑结构与数据元素本身的内容和形式无关。
(V )2. 一个数据结构是由一个逻辑结构和这个逻辑结构上的一个基本运算集构成的整体。
(V )3. 数据元素是数据的最小单位。
(X ) 4. 数据的逻辑结构和数据的存储结构是相同的。
(X ) 5. 程序和算法原则上没有区别,所以在讨论数据结构时可以通用。
(X ) 6. 从逻辑关系上讲,数据结构主要分为线性结构和非线性结构两类。
(V ) 7. 数据的存储结构是数据的逻辑结构的存储映象。
(V ) 8. 数据的物理结构是指数据在计算机内实际的存储形式。
(V ) 9. 数据的逻辑结构是依赖于计算机的。
(X )10. 算法是对解题方法和步骤的描述。
(V )二、填空题1. 数据有逻辑结构和存储结构两种结构。
-----------------2. 数据逻辑结构除了集合以外,还包括线性结构、树形结构和图形结构。
_________3. 数据结构按逻辑结构可分为两大类,它们是线性结构和非线性结构。
---------4. 树形结构和图形结构合称为非线性结构。
---------------------------------5. 在树形结构中,除了树根结点以外,其余每个结点只有1个前驱结点。
_6. 在图形结构中,每个结点的前驱结点数和后继结点数可以任意多个。
___________7. 数据的存储结构又叫物理结构。
________________8. 数据的存储结构形式包括顺序存储、链式存储、索引存储和散列存储 -------9. 线性结构中的元素之间存在一对一的关系。
------------- 10. 树形结构中的元素之间存在一对多的关系。
_____________ 11. 图形结构的元素之间存在多对多的关系。
--------------12. 数据结构主要研究数据的逻辑结构、存储结构和算法(或运算)3个方面的内容。
数据结构课后习题详解(超完整超经典)第1章绪论1.1简述下列术语:数据,数据元素、数据对象、数据结构、存储结构、数据类型和抽象数据类型。
解:数据是对客观事物的符号表示。
在计算机科学中是指所有能输入到计算机中并被计算机程序处理的符号的总称。
数据元素是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。
数据对象是性质相同的数据元素的集合,是数据的一个子集。
数据结构是相互之间存在一种或多种特定关系的数据元素的集合。
存储结构是数据结构在计算机中的表示。
数据类型是一个值的集合和定义在这个值集上的一组操作的总称。
抽象数据类型是指一个数学模型以及定义在该模型上的一组操作。
是对一般数据类型的扩展。
1.2试描述数据结构和抽象数据类型的概念与程序设计语言中数据类型概念的区别。
解:抽象数据类型包含一般数据类型的概念,但含义比一般数据类型更广、更抽象。
一般数据类型由具体语言系统内部定义,直接提供给编程者定义用户数据,因此称它们为预定义数据类型。
抽象数据类型通常由编程者定义,包括定义它所使用的数据和在这些数据上所进行的操作。
在定义抽象数据类型中的数据部分和操作部分时,要求只定义到数据的逻辑结构和操作说明,不考虑数据的存储结构和操作的具体实现,这样抽象层次更高,更能为其他用户提供良好的使用接口。
1.3设有数据结构(D,R),其中Dd1,d2,d3,d4,Rr,rd1,d2,d2,d3,d3,d4试按图论中图的画法惯例画出其逻辑结构图。
解:1.4试仿照三元组的抽象数据类型分别写出抽象数据类型复数和有理数的定义(有理数是其分子、分母均为自然数且分母不为零的分数)。
解:数据对象:D={r,i|r,i为实数}数据关系:R={}基本操作:操作结果:构造一个复数C,其实部和虚部分别为re和imDetroyCmople某(&C)操作结果:销毁复数CGet(C,k,&e)操作结果:用e返回复数C的第k元的值操作结果:改变复数C的第k元的值为e操作结果:如果复数C的两个元素按升序排列,则返回1,否则返回0Put(&C,k,e)IAcending(C)ADTRationalNumber{数据对象:D={,m|,m为自然数,且m不为0}数据关系:R={}基本操作:InitRationalNumber(&R,,m)操作结果:构造一个有理数R,其分子和分母分别为和mDetroyRationalNumber(&R)操作结果:销毁有理数RGet(R,k,&e)操作结果:用e返回有理数R的第k元的值操作结果:改变有理数R 的第k元的值为e操作结果:若有理数R的两个元素按升序排列,则返回1,否则返回0操作结果:若有理数R的两个元素按降序排列,则返回1,否则返回0操作结果:用e返回有理数R的两个元素中值较大的一个操作结果:用e 返回有理数R的两个元素中值较小的一个Put(&R,k,e)IAcending(R)IDecending(R)Ma某(R,&e)Min(R,&e) IDecending(C)操作结果:如果复数C的两个元素按降序排列,则返回1,否则返回0操作结果:用e返回复数C的两个元素中值较大的一个操作结果:用e 返回复数C的两个元素中值较小的一个Ma某(C,&e)Min(C,&e) }ADTRationalNumber(1)product=1;i=1;while(i<=n){product某=i;i++;}(2)i=0;do{i++;}while((i!=n)&&(a[i]!=某));(3)witch{cae某1.5试画出与下列程序段等价的框图。
第一章习题一、问答题1. 什么是数据结构?2. 叙述四类基本数据结构的名称与含义。
3. 叙述算法的定义与特性。
4. 叙述算法的时间复杂度。
5. 叙述数据类型的概念。
6. 叙述线性结构与非线性结构的差别。
7. 叙述面向对象程序设计语言的特点。
8. 在面向对象程序设计中,类的作用是什么?9. 叙述参数传递的主要方式及特点。
10. 叙述抽象数据类型的概念。
二、判断题(在各题后填写“/或“ X”)1. 线性结构只能用顺序结构来存放,非线性结构只能用非顺序结构来存放。
( )2. 算法就是程序。
( )3. 在高级语言(如C或PASCAL中,指针类型是原子类型。
( )三、计算下列程序段中X=X+1的语句频度for(i=1;i<=n;i++)for(j=1;j<=i;j++)for(k=1;k<=j;k++)x=x+1;四、试编写算法,求一元多项式P n(x)=a o+a i x+a2x2+a s x3+,a n x n的值P n(x o),并确定算法中的每一语句的执行次数和整个算法的时间复杂度,要求时间复杂度尽可能小,规定算法中不能使用求幕函数。
注意:本题中的输入a(i=0,1,,,n),x 和n,输出为P n(x0)。
通常算法的输入和输出可采用下列两种方式之一:1)通过参数表中的参数显式传递。
试讨论这两种方法的优缺点,并在本题算法中以你认为较好的一种方式实现输入和输出2)通过全局变量隐式传递。
实习题设计实现抽象数据类型“有理数”。
基本操作包括有理数的加法、减法、乘法、除法,以及求有理数的分子、分母。
第一章答案1.3 计算下列程序中x=x+1 的语句频度for(i=1;i<=n;i++)for(j=1;j<=i;j++)for(k=1;k<=j;k++)x=x+1;【解答】x=x+1 的语句频度为:T(n)=1+(1+2)+ (1+2+3 ) +……+ (1+2+……+n ) =n(n+1)(n+2)/61. 4试编写算法,求p n(x)=a o+a i x+a2x2+ .............. .+a n x n的值P n(x o),并确定算法中每一语句的执行次数和整个算法的时间复杂度,要求时间复杂度尽可能小,规定算法中不能使用求幂函数。