南邮_数据结构作业答案讲解教学教材
- 格式:ppt
- 大小:295.00 KB
- 文档页数:49
数据结构第1~3章作业参考答案【1.4】【解法一】⑴抽象数据类型复数:ADT Complex{数据对象:D={ci|ci∈R, i=1,2, 其中R为实数集}数据关系:R={<c1,c2>| ci∈D, i=1,2, 其中c1为复数实部, c2为复数虚部}基本操作:InitComplex (&C,v1,v2)操作结果:构造一个复数C,元素c1, c2分别被赋以参数v1, v2的值。
DestroyComplex(&C)初始条件:复数C已存在。
操作结果:销毁复数C。
GetReal(C, &e)初始条件:复数C已存在。
操作结果:用e返回复数C实部的值。
Get Imaginary(C, &e)初始条件:复数C已存在。
操作结果:用e返回复数C虚部的值。
SetReal(&C, e)初始条件:复数C已存在。
操作结果:用e更新复数C实部的值。
Set Imaginary(&C, e)初始条件:复数C已存在。
操作结果:用e更新复数C虚部的值。
AdditionComplex (&C, C1, C2)初始条件:复数C1,C2已存在。
操作结果:复数C1与复数C2相加,用复数C返回其和。
SubstractComplex(&C, C1, C2)初始条件:复数C1,C2已存在。
操作结果:复数C1减去复数C2,用复数C返回其差。
MultipleComplex(&C, C1, C2 )初始条件:复数C1,C2已存在。
操作结果:复数C1与复数C2相乘,用复数C返回其积。
DividedComplex(&C, C1, C2)初始条件:复数C1,C2已存在,且C2≠0。
操作结果:复数C1除以复数C2,用复数C返回其商。
ModulusComplex(C, &e)初始条件:复数C已存在。
操作结果:求复数C的模,用e返回。
ConjugateComplex(&C, C1)初始条件:复数C1已存在。
9.1(2)(3)⎥⎥⎥⎥⎥⎥⎥⎥⎦⎤⎢⎢⎢⎢⎢⎢⎢⎢⎣⎡0000011000110101000100100010010000009.29.4template <class T>void LGraph<T>::Degree(int *in) { for (int i=0;i<n;i++) { in[i]=0;}ENode<T> *p; for (i=0; i<n; i++) { p=a[i];while (p){in[p->adjvex]++;p=p->nextarc;}}for (i=0;i<n;i++){cout<<i<<": " << in[i] << "; " << endl;}}9.69.139.16设AOE网如图题9-4所示。
求各事件的可能的最早发生时间和允许的最迟发生时间,各活动可能的最早开始时间河运许的最晚开始时间,以及关键活动和关键路径及其长度。
关键路径:a 2,a 7,a 9. 长度:239.17使用普里姆算法以1为源点,画出图题9-5的无向图的最小代价生成树。
9.18使用克鲁斯 卡尔算法以,画出图题9-5的无向图的最小代价生成树9.21用迪杰斯特拉算法求图题9-6的有向图中以顶点A 为源点的单源最短路径。
写出一维数组d 和 path 在执行该算法的过程中各步的状态。
9.22用弗洛伊德算法求图题9-6的有向图的所有顶点之间的最短路径。
写出二维数组d 和path 在执行该算法的过程中各步的状态。
(1)初始状态dA pathAdCpathCdDpathDdE dG。
第1 章绪论一、基础题1. A2. C3. C4. A5. C二、扩展题1.数据是计算机加工处理的对象;数据元素是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理;数据项是组成数据元素的、不可分割的最小单位。
2.数据结构是按某种逻辑关系组织起来的数据元素的集合,使用计算机语言描述并按一定的存储方式存储在计算机中,并在其上定义了一组运算。
3.集合结构、线性结构、树形结构和图形结构。
集合结构中,元素之间没有关系;线性结构中,元素之间存在一对一的关系;树形结构中,元素之间存在一对多的关系,其中最多只有一个元素没有前驱元素,这个元素就是根;图形结构中,元素之间存在多对多的关系。
4.顺序存储、链式存储、索引存储和散列存储。
5.一个算法是对特定问题的求解步骤的一种描述,是指令的有限序列。
其特征包括:➢输入:算法有零个或多个输入➢输出:算法至少产生一个输出➢确定性:算法的每一条指令都有确切的定义,没有二义性。
➢能行性/可行性:可以通过已经实现的基本运算执行有限次来实现➢有穷性:算法必须总能在执行有限步之后终止6.联系:程序是计算机指令的有序集合,是算法用某种程序设计语言的表述,是算法在计算机上的具体实现。
区别:在语言描述上不同,程序必须是用规定的程序设计语言来写,而算法的描述形式包括自然语言、伪代码、流程图和程序语言等;算法所描述的步骤一定是有限的,而程序可以无限地执行下去,比如一个死循环可以称为程序,但不能称为算法。
7.正确性:算法的执行结果应当满足功能需求,无语法错误,无逻辑错误简明性:思路清晰、层次分明、易读易懂,有利于调试维护健壮性:当输入不合法数据时,应能做适当处理,不至于引起严重后果效率:有效使用存储空间和有高的时间效率最优性:解决同一个问题可能有多种算法,应进行比较,选择最佳算法可使用性:用户友好性8(1)执行次数为n-1(n>=2),n=1时执行1次;时间复杂度为O(n)。
(2)执行次数为⌈log3n⌉;时间复杂度为O(logn)(3) 执行次数为n2;时间复杂度为O(n2)(4)执行次数为⌊√n⌋ + 1;时间复杂度为O(√n)第2 章线性表1.A2.D3.B4.C5.B6.D7.D8.C9.A10.D1.编写程序实现对顺序表逆置。
9.1(3)「00000o-100100 010010 001010 110001 100000生成的邻接表9.4template <class T>void LGraph<T>::Degree(int *in) ( -for (int i=0;i<n;i++){in[i]=0;}ENode<T> *p;for (i=0; i<n; i++)P=a[i];while (p)(in[p->adjvex]++;p=p->nextarc;}}for (i=0;i<n;i++)(cout«i«n: " « in[i] «" « endl;}以2为起始顶点的深度优先搜索得到的生成树9.139. 16设A0E网如图题9-4所示。
求各事件的可能的最早发生时间和允许的最迟发生时间,各活动可能的最早开始时间河运许的最晚开始时间,以及关键活动和关键路径及其长度。
9.6O54333333352252222512511④所有可能的拓扑序列(b)按邻接表的拓扑序9.17以2为起始顶点的广度优先题图9.4关键路径:a.2, a?, ag. 长度:239. 17使用普里姆算法以1为源点,画出图题9-5的无向图的最小代价生成树。
9. 18使用克鲁斯卡尔算法以,画出图题9-5的无向图的最小代价生成树9. 21用迪杰斯特拉算法求图题9-6的有向图中以顶点A 为源点的单源最短路径。
写出一维数 组d 和path 在执行该算法的过程中各步的状态。
源点终点 最短路径 路径长度 AB (A, B) 3C (A, B, C) 4D (A, D) 4E (A, B, E) 4G _ 8Sd[A]path[A] d[B] path[B] d[C] path[C] d[D] path[D] d[E] path[E] d[G] path[G] A 0,-1 3, A °°, -1 4, A 5, A °°, -1 B 0,-1 3, A 4,B 4, A 4,B °°, -1 C 0,-1 3, A4,B4, A4,B°°, -1D 0,-1 3, A 4,B 4, A 4,B 8, -1E 0,-1 3, A 4,B 4, A 4,B °°, "I9. 22用弗洛伊德算法求图题9-6的有向图的所有顶点之间的最短路径。
数据结构(第二版)课后习题答案第一章:数据结构概述数据结构是计算机科学中非常重要的一个概念,它用于组织和管理计算机内部存储的数据。
数据结构的设计直接影响到程序的运行效率和对真实世界问题的建模能力。
第二版的《数据结构》教材旨在帮助读者更好地理解和应用数据结构。
为了提高学习效果,每章节后都附有一系列习题。
本文将为第二版《数据结构》教材中的部分习题提供详细的答案和解析。
第二章:线性表2.1 顺序表习题1:请问如何判断顺序表是否为空表?答案:当顺序表的长度为0时,即为空表。
解析:顺序表是用一块连续的内存空间存储数据元素的线性结构。
当顺序表中没有元素时,长度为0,即为空表。
习题2:如何求顺序表中第i个元素的值?答案:可以通过访问顺序表的第i-1个位置来获取第i个元素的值。
解析:顺序表中的元素在内存中是连续存储的,通过下标访问元素时,需要将下标减1,因为数组是从0开始编号的。
2.2 链表习题1:请问链表中的结点包含哪些信息?答案:链表的结点一般包含两部分信息:数据域和指针域。
解析:数据域用于存储数据元素的值,指针域用于存储指向下一个结点的指针。
习题2:如何删除链表中的一个结点?答案:删除链表中的一个结点需要将其前一个结点的指针指向其后一个结点,然后释放被删除结点的内存空间。
解析:链表的删除操作相对简单,只需要通过修改指针的指向即可。
但需要注意释放被删除结点的内存空间,防止内存泄漏。
第三章:栈和队列3.1 栈习题1:如何判断栈是否为空?答案:当栈中没有任何元素时,即为空栈。
解析:栈是一种先进后出(Last In First Out,LIFO)的数据结构,栈顶指针指向栈顶元素。
当栈中没有元素时,栈顶指针为空。
习题2:请问入栈和出栈操作的时间复杂度是多少?答案:入栈和出栈操作的时间复杂度均为O(1)。
解析:栈的入栈和出栈操作只涉及栈顶指针的改变,不受栈中元素数量的影响,因此时间复杂度为O(1)。
3.2 队列习题1:请问队列可以用哪些方式实现?答案:队列可以用数组或链表来实现。
数据结构_南京邮电大学中国大学mooc课后章节答案期末考试题库2023年1.向最大堆84,49,82,26,29,46依次插入元素94,99,89,80,94,最终得到的最大堆是____________(提示:堆的元素插入操作需调用AdjustUp方法,请将答案表示成元素序列,并用半角逗号相隔,答案中不要有空格)。
参考答案:99,94,84,89,94,46,82,26,49,29,802.设有5×8的数组A,其每个元素占2个字节,已知A[0][4]在内存中的地址是120,按列优先顺序存储,A[2][6]的地址是_________ 。
参考答案:1443.以下选项_____是下图的深度优先遍历序列。
【图片】参考答案:K,D,A,B,E,C,F,G,J,H,I4.对最大堆序列95,61,66,9,19,27执行1次删除操作(提示:对优先级队列执行删除操作默认删除堆顶元素)后得到最大堆序列_____________(提示:堆元素删除操作需调用AdjustDown方法,请将答案表示成元素序列,并用半角逗号相隔,答案中不要有空格)。
参考答案:66,61,27,9,195.求该方法的渐近时间复杂度为__________.(注意填写答案时不要有空格,用x^y的方式表达x的y次方)void aFunc(int n) { for (int i = 0; i < n; i++) { for (int j = i; j < n; j++) { printf("Hello World\n"); } }}O(n^2)6.已知图的边集合:【图片】若采用邻接表存储,则顶点4对应的边结点链表中共有_________个边结点。
参考答案:27.用克鲁斯卡尔算法构造下图的最小代价生成树,第一条被加入生成树上的边一定是(E,C)。
【图片】参考答案:正确8.假设一棵含有18个结点的完全二叉树中,按层次从上到下、每层结点从左到右的顺序,从0开始编号,则编号为14的结点的左孩子编号为_______(如果孩子不存在,则填写NULL)。