数据结构习题和答案及解析

第 1 章绪论

课后习题讲解

1. 填空

⑴()是数据的基本单位,在计算机程序中通常作为一个整体进行考虑与处理。

【解答】数据元素

⑵()是数据的最小单位,()是讨论数据结构时涉及的最小数据单位。

【解答】数据项,数据元素

【分析】数据结构指的是数据元素以及数据元素之间的关系。

⑶从逻辑关系上讲,数据结构主要分为()、()、()与()。【解答】集合,线性结构,树结构,图结构

⑷数据的存储结构主要有()与()两种基本方法,不论哪种存储结构,都要存储两方面的内容:()与()。

【解答】顺序存储结构,链接存储结构,数据元素,数据元素之间的关系

⑸算法具有五个特性,分别是()、()、()、()、()。【解答】有零个或多个输入,有一个或多个输出,有穷性,确定性,可行性

⑹算法的描述方法通常有()、()、()与()四种,其中,()被称为算法语言。

【解答】自然语言,程序设计语言,流程图,伪代码,伪代码

⑺在一般情况下,一个算法的时间复杂度是()的函数。

【解答】问题规模

⑻设待处理问题的规模为n,若一个算法的时间复杂度为一个常数,则表示成数量级的形式为(),若为n*log25n,则表示成数量级的形式为()。

【解答】Ο(1),Ο(nlog2n)

【分析】用大O记号表示算法的时间复杂度,需要将低次幂去掉,将最高次幂的系数去掉。

2. 选择题

⑴顺序存储结构中数据元素之间的逻辑关系是由()表示的,链接存储结构中的数据元素之间的逻辑关系是由()表示的。

A 线性结构

B 非线性结构

C 存储位置

D 指针

【解答】C,D

【分析】顺序存储结构就是用一维数组存储数据结构中的数据元素,其逻辑关系由存储位置(即元素在数组中的下标)表示;链接存储结构中一个数据元素对应链表中的一个结点,元素之间的逻辑关系由结点中的指针表示。

⑵假设有如下遗产继承规则:丈夫与妻子可以相互继承遗产;子女可以继承父亲或母亲的遗产;子女间不能相互继承。则表示该遗产继承关系的最合适的数据结构应该是()。

A 树

B 图

C 线性表

D 集合

【解答】B

【分析】将丈夫、妻子与子女分别作为数据元素,根据题意画出逻辑结构图。

⑶算法指的是()。

A 对特定问题求解步骤的一种描述,是指令的有限序列。

B 计算机程序

C 解决问题的计算方法

D 数据处理

【解答】A

【分析】计算机程序是对算法的具体实现;简单地说,算法是解决问题的方法;数据处理是通过算法完成的。所以,只有A是算法的准确定义。

⑷下面()不是算法所必须具备的特性。

A 有穷性

B 确切性

C 高效性

D 可行性

【解答】C

【分析】高效性是好算法应具备的特性。

⑸算法分析的目的是(),算法分析的两个主要方面是()。

A 找出数据结构的合理性

B 研究算法中输入与输出的关系

C 分析算法的效率以求改进

D 分析算法的易读性与文档性

E 空间性能与时间性能

F 正确性与简明性

G 可读性与文档性H 数据复杂性与程序复杂性

【解答】C,E

3. 判断题

⑴算法的时间复杂度都要通过算法中的基本语句的执行次数来确定。

【解答】错。时间复杂度要通过算法中基本语句执行次数的数量级来确定。

⑵每种数据结构都具备三个基本操作:插入、删除与查找。

【解答】错。如数组就没有插入与删除操作。此题注意是每种数据结构。

⑶所谓数据的逻辑结构指的是数据之间的逻辑关系。

【解答】错。是数据之间的逻辑关系的整体。

⑷逻辑结构与数据元素本身的内容与形式无关。

【解答】对。因此逻辑结构是数据组织的主要方面。

⑸基于某种逻辑结构之上的基本操作,其实现是唯一的。

【解答】错。基本操作的实现是基于某种存储结构设计的,因而不是唯一的。

4. 分析以下各程序段,并用大O记号表示其执行时间。

【解答】⑴基本语句是k=k+10*i,共执行了n-2次,所以T(n)=O(n)。

⑵基本语句是k=k+10*i,共执行了n次,所以T(n)=O(n)。

⑶分析条件语句,每循环一次,i+j 整体加1,共循环n次,所以T(n)=O(n)。

⑷设循环体共执行T(n)次,每循环一次,循环变量y加1,最终

T(n)=y,即:

(T(n)+1)2≤n,所以T(n)=O(n1/2)。

⑸x++是基本语句,所以

5.设有数据结构(D,R),其中D={1, 2, 3, 4, 5, 6},

R={(1,2),(2,3),(2,4),(3,4),(3,5),(3,6),(4,5),(4,6)}。试画出其逻辑结构图并指出属于何种结构。

【解答】其逻辑结构图如图1-3所示,它是一种图结构。

6. 为整数定义一个抽象数据类型,包含整数的常见运算,每个运算对应一个基本操作,每个基本操作的接口需定义前置条件、输入、功能、输出与后置条件。

【解答】整数的抽象数据类型定义如下:

ADT integer

Data

整数a:可以是正整数(1, 2, 3, … )、负整数(-1, -2, -3, …)与零Operation

Constructor

前置条件:整数a不存在

输入:一个整数b

功能:构造一个与输入值相同的整数

输出:无

后置条件:整数a具有输入的值

Set

前置条件:存在一个整数a

输入:一个整数b

功能:修改整数a的值,使之与输入的整数值相同

输出:无

后置条件:整数a的值发生改变

Add

前置条件:存在一个整数a

输入:一个整数b

功能:将整数a与输入的整数b相加

输出:相加后的结果

后置条件:整数a的值发生改变

Sub

前置条件:存在一个整数a

输入:一个整数b

功能:将整数a与输入的整数b相减

输出:相减的结果

后置条件:整数a的值发生改变

Multi

前置条件:存在一个整数a

输入:一个整数b

功能:将整数a与输入的整数b相乘

输出:相乘的结果

后置条件:整数a的值发生改变

Div

前置条件:存在一个整数a

输入:一个整数b

功能:将整数a与输入的整数b相除

输出:若整数b为零,则抛出除零异常,否则输出相除的结果后置条件:整数a的值发生改变

Mod

前置条件:存在一个整数a

输入:一个整数b

功能:求当前整数与输入整数的模,即正的余数

输出:若整数b为零,则抛出除零异常,否则输出取模的结果

后置条件:整数a的值发生改变

Equal

前置条件:存在一个整数a

输入:一个整数b

功能:判断整数a与输入的整数b是否相等

输出:若相等返回1,否则返回0

后置条件:整数a的值不发生改变

endADT

7. 求多项式A(x)的算法可根据下列两个公式之一来设计:

⑴A(x)=anxn+an-1xn-1+…+a1x+a0

⑵A(x)=(…(anx+an-1)x+…+a1)x)+a0

根据算法的时间复杂度分析比较这两种算法的优劣。

【解答】第二种算法的时间性能要好些。第一种算法需执行大量的乘法运算,而第二种算法进行了优化,减少了不必要的乘法运算。8. 算法设计(要求:算法用伪代码与C++描述,并分析最坏情况下的时间复杂度)

⑴对一个整型数组A[n]设计一个排序算法。

【解答】下面是简单选择排序算法的伪代码描述。

下面是简单选择排序算法的C++描述。

分析算法,有两层嵌套的for循环,所以,。

⑵找出整型数组A[n]中元素的最大值与次最大值。

【解答】算法的伪代码描述如下:

算法的C++描述如下:

分析算法,只有一层循环,共执行n-2次,所以,T(n)=O(n)。

学习自测及答案

1.顺序存储结构的特点是(),链接存储结构的特点是()。【解答】用元素在存储器中的相对位置来表示数据元素之间的逻辑关系,用指示元素存储地址的指针表示数据元素之间的逻辑关系。

2. 算法在发生非法操作时可以作出处理的特性称为()。

【解答】健壮性

3. 常见的算法时间复杂度用大O记号表示为:常数阶( )、对数阶( )、线性阶( )、平方阶( )与指数阶( )。

【解答】O(1),O(log2n),O(n),O(n2),O(2n)

4.将下列函数按它们在n 时的无穷大阶数,从小到大排列。

n, n-n3+7n5, nlogn, 2n/2, n3, log2n, n1/2+log2n, (3/2)n, n!, n2+log2n

【解答】log2n, n1/2+log2n, n, nlog2n, n2+log2n, n3,

n-n3+7n5, 2n/2, (3/2)n, n!

5.试描述数据结构与抽象数据类型的概念与程序设计语言中数据类型概念的区别。

【解答】数据结构是指相互之间存在一定关系的数据元素的集合。而抽象数据类型是指一个数据结构以及定义在该结构上的一组操作。程序设计语言中的数据类型是一个值的集合与定义在这个值集上一组操作的总称。抽象数据类型可以看成是对数据类型的一种抽象。

6. 对下列用二元组表示的数据结构,试分别画出对应的逻辑结构图,并指出属于何种结构。

⑴A=(D,R),其中D={a1, a2, a3, a4},R={ }

⑵B=(D,R),其中D={a, b, c, d, e, f},R={,,,,}

⑶C=( D,R),其中D={a,b,c,d,e,f},R={,,,,,}

⑷D=(D,R),其中D={1, 2, 3, 4, 5, 6},

R={(1, 2),(1, 4),(2, 3),(2, 4),(3, 4),(3, 5),(3, 6),(4, 6)} 【解答】⑴属于集合,其逻辑结构图如图1-4(a)所示;⑵属于线性结构,其逻辑结构图如图1-4(b)所示;⑶属于树结构,其逻辑结构图如图1-4(c)所示;⑷属于图结构,其逻辑结构图如图1-4(d)所示。

7. 求下列算法的时间复杂度。

count=0; x=1;

while (x {

x*=2;

count++;

}

return count;

【解答】O(log2n)

第2 章线性表

课后习题讲解

1. 填空

⑴在顺序表中,等概率情况下,插入与删除一个元素平均需移动()个元素,具体移动元素的个数与()与()有关。

【解答】表长的一半,表长,该元素在表中的位置

⑵顺序表中第一个元素的存储地址是100,每个元素的长度为2,则第5个元素的存储地址是()。

【解答】108

【分析】第5个元素的存储地址=第1个元素的存储地址+(5-

1)×2=108

⑶设单链表中指针p 指向结点A,若要删除A的后继结点(假设A 存在后继结点),则需修改指针的操作为()。

【解答】p->next=(p->next)->next

⑷单链表中设置头结点的作用是()。

【解答】为了运算方便

【分析】例如在插入与删除操作时不必对表头的情况进行特殊处理。

⑸非空的单循环链表由头指针head指示,则其尾结点(由指针p 所指)满足()。

【解答】p->next=head

【分析】如图2-8所示。

⑹在由尾指针rear指示的单循环链表中,在表尾插入一个结点s的操作序列是();删除开始结点的操作序列为()。

【解答】s->next =rear->next; rear->next =s; rear =s;

q=rear->next->next; rear->next->next=q->next; delete q; 【分析】操作示意图如图2-9所示:

⑺一个具有n个结点的单链表,在指针p所指结点后插入一个新结点的时间复杂度为();在给定值为x的结点后插入一个新结点的时间复杂度为()。

【解答】Ο(1),Ο(n)

【分析】在p所指结点后插入一个新结点只需修改指针,所以时间复

杂度为Ο(1);而在给定值为x的结点后插入一个新结点需要先查找值为x的结点,所以时间复杂度为Ο(n)。

⑻可由一个尾指针唯一确定的链表有()、()、()。

【解答】循环链表,循环双链表,双链表

2. 选择题

⑴线性表的顺序存储结构是一种()的存储结构,线性表的链接存储结构是一种()的存储结构。

A 随机存取

B 顺序存取

C 索引存取

D 散列存取

【解答】A,B

【分析】参见2.2.1。

⑵线性表采用链接存储时,其地址()。

A 必须是连续的

B 部分地址必须是连续的

C 一定是不连续的

D 连续与否均可以

【解答】D

【分析】线性表的链接存储是用一组任意的存储单元存储线性表的数据元素,这组存储单元可以连续,也可以不连续,甚至可以零散分布在内存中任意位置。

⑶单循环链表的主要优点是()。

A 不再需要头指针了

B 从表中任一结点出发都能扫描到整个链表;

C 已知某个结点的位置后,能够容易找到它的直接前趋;

D 在进行插入、删除操作时,能更好地保证链表不断开。

【解答】B

⑷链表不具有的特点是()。

A 可随机访问任一元素

B 插入、删除不需要移动元素

C 不必事先估计存储空间

D 所需空间与线性表长度成正比

【解答】A

⑸若某线性表中最常用的操作是取第i 个元素与找第i个元素的前趋,则采用()存储方法最节省时间。

A 顺序表

B 单链表

C 双链表

D 单循环链表

【解答】A

【分析】线性表中最常用的操作是取第i 个元素,所以,应选择随机存取结构即顺序表,同时在顺序表中查找第i个元素的前趋也很方便。单链表与单循环链表既不能实现随机存取,查找第i个元素的前趋也不方便,双链表虽然能快速查找第i个元素的前趋,但不能实现随机存取。

⑹若链表中最常用的操作是在最后一个结点之后插入一个结点与删除第一个结点,则采用()存储方法最节省时间。

A 单链表

B 带头指针的单循环链表

C 双链表

D 带尾指针的单循环链表

【解答】D

【分析】在链表中的最后一个结点之后插入一个结点需要知道终端结点的地址,所以,单链表、带头指针的单循环链表、双链表都不合适,考虑在带尾指针的单循环链表中删除第一个结点,其时间性能是

O(1),所以,答案是D 。

⑺若链表中最常用的操作是在最后一个结点之后插入一个结点与删除最后一个结点,则采用()存储方法最节省运算时间。

A 单链表

B 循环双链表C单循环链表 D 带尾指针的单循环链表

【解答】B

【分析】在链表中的最后一个结点之后插入一个结点需要知道终端结点的地址,所以,单链表、单循环链表都不合适,删除最后一个结点需要知道终端结点的前驱结点的地址,所以,带尾指针的单循环链表不合适,而循环双链表满足条件。

⑻在具有n个结点的有序单链表中插入一个新结点并仍然有序的时间复杂度是()。

A O(1)

B O(n)

C O(n2)

D O(nlog2n)

【解答】B

【分析】首先应顺序查找新结点在单链表中的位置。

⑼对于n个元素组成的线性表,建立一个有序单链表的时间复杂度是()。

A O(1)

B O(n)

C O(n2)

D O(nlog2n)

【解答】C

【分析】该算法需要将n个元素依次插入到有序单链表中,而插入每个元素需O(n)。

⑽使用双链表存储线性表,其优点是可以()。

A 提高查找速度

B 更方便数据的插入与删除

C 节约存储空间

D 很快回收存储空间

【解答】B

【分析】在链表中一般只能进行顺序查找,所以,双链表并不能提高查找速度,因为双链表中有两个指针域,显然不能节约存储空间,对于动态存储分配,回收存储空间的速度是一样的。由于双链表具有对称性,所以,其插入与删除操作更加方便。

⑾在一个单链表中,已知q所指结点是p所指结点的直接前驱,若在q与p之间插入s所指结点,则执行()操作。

A s->next=p->next; p->next=s;

B q->next=s; s->next=p;

C p->next=s->next; s->next=p;

D p->next=s; s->next=q; 【解答】B

【分析】注意此题是在q与p之间插入新结点,所以,不用考虑修改指针的顺序。

⑿在循环双链表的p所指结点后插入s所指结点的操作是()。

A p->next=s; s->prior=p; p->next->prior=s; s->next=p->next;

B p->next=s; p->next->prior=s; s->prior=p; s->next=p->next;

C s->prior=p; s->next=p->next; p->next=s; p->next->prior=s;

D s->prior=p; s->next=p->next; p->next->prior=s; p->next=s 【解答】D

【分析】在链表中,对指针的修改必须保持线性表的逻辑关系,否则,将违背线性表的逻辑特征,图2-10给出备选答案C与D的图解。

3. 判断题

⑴线性表的逻辑顺序与存储顺序总是一致的。

【解答】错。顺序表的逻辑顺序与存储顺序一致,链表的逻辑顺序与存储顺序不一定一致。

⑵线性表的顺序存储结构优于链接存储结构。

【解答】错。两种存储结构各有优缺点。

⑶设p,q是指针,若p=q,则*p=*q。

【解答】错。p=q只能表示p与q指向同一起始地址,而所指类型则不一定相同。

⑷线性结构的基本特征是:每个元素有且仅有一个直接前驱与一个直接后继。

【解答】错。每个元素最多只有一个直接前驱与一个直接后继,第一个元素没有前驱,最后一个元素没有后继。

⑸在单链表中,要取得某个元素,只要知道该元素所在结点的地址即可,因此单链表是随机存取结构。

【解答】错。要找到该结点的地址,必须从头指针开始查找,所以单链表是顺序存取结构。

4.请说明顺序表与单链表各有何优缺点,并分析下列情况下,采用何种存储结构更好些。

⑴若线性表的总长度基本稳定,且很少进行插入与删除操作,但要求以最快的速度存取线性表中的元素。

⑵如果n个线性表同时并存,并且在处理过程中各表的长度会动态发生变化。

⑶描述一个城市的设计与规划。

【解答】顺序表的优点:①无需为表示表中元素之间的逻辑关系而增加额外的存储空间;②可以快速地存取表中任一位置的元素(即随机存取)。顺序表的缺点:①插入与删除操作需移动大量元素;

②表的容量难以确定;③造成存储空间的“碎片”。

单链表的优点:①不必事先知道线性表的长度;②插入与删除元素时只需修改指针,不用移动元素。单链表的缺点:①指针的结构性开销;②存取表中任意元素不方便,只能进行顺序存取。

⑴应选用顺序存储结构。因为顺序表是随机存取结构,单链表是顺序存取结构。本题很少进行插入与删除操作,所以空间变化不大,且需要快速存取,所以应选用顺序存储结构。

⑵应选用链接存储结构。链表容易实现表容量的扩充,适合表的长

度动态发生变化。

⑶应选用链接存储结构。因为一个城市的设计与规划涉及活动很多,需要经常修改、扩充与删除各种信息,才能适应不断发展的需要。而顺序表的插入、删除的效率低,故不合适。

5.算法设计

⑴设计一个时间复杂度为O(n)的算法,实现将数组A[n]中所有元素循环右移k个位置。

【解答】算法思想请参见主教材第一章思想火花。下面给出具体算法。分析算法,第一次调用Reverse函数的时间复杂度为O(k),第二次调用Reverse函数的时间复杂度为O(n-k),第三次调用Reverse函数的时间复杂度为O(n),所以,总的时间复杂度为O(n)。

⑵已知数组A[n]中的元素为整型,设计算法将其调整为左右两部分,左边所有元素为奇数,右边所有元素为偶数,并要求算法的时间复杂度为O(n)。

【解答】从数组的两端向中间比较,设置两个变量i与j,初始时i=0,j=n-1,若A[i]为偶数并且A[j]为奇数,则将A[i]与A[j]交换。具体算法如下:

分析算法,两层循环将数组扫描一遍,所以,时间复杂度为O(n)。

⑶试编写在无头结点的单链表上实现线性表的插入操作的算法,并与带头结点的单链表上的插入操作的实现进行比较。

【解答】参见2.2.3。

⑷试分别以顺序表与单链表作存储结构,各写一实现线性表就地逆置的算法。

【解答】顺序表的逆置,即是将对称元素交换,设顺序表的长度为length,则将表中第i个元素与第length-i-1个元素相交换。具体算法如下:

单链表的逆置请参见2.2.4算法2-4与算法2-6。

⑸假设在长度大于1的循环链表中,即无头结点也无头指针,s为指向链表中某个结点的指针,试编写算法删除结点s的前趋结点。【解答】利用单循环链表的特点,通过指针s可找到其前驱结点r以及r的前驱结点p,然后将结点r删除,如图2-11所示,具体算法如下:

⑹已知一单链表中的数据元素含有三类字符:字母、数字与其他字符。试编写算法,构造三个循环链表,使每个循环链表中只含同一类字符。

【解答】在单链表A中依次取元素,若取出的元素是字母,把它插入到字母链表B 中,若取出的元素是数字,则把它插入到数字链表

最新版数据结构1800题含完整答案详解

数据结构1800例题与答案 第一章绪论 一、选择题(每小题2分) 1.算法的计算量的大小称为计算的( B )。【北京邮电大学2000 二、3 (20/8分)】 A.效率B.复杂性C.现实性D.难度 2.算法的时间复杂度取决于(C)。【中科院计算所1998 二、1 (2分)】 A.问题的规模B.待处理数据的初态C.A和B D.都不是 3.计算机算法指的是(①C ),它必须具备(② B )这三个特性。 ①A.计算方法B.排序方法 C.解决问题的步骤序列D.调度方法 ②A.可执行性、可移植性、可扩充性B.可执行性、确定性、有穷性 C.确定性、有穷性、稳定性D.易读性、稳定性、安全性【南京理工大学1999 一、1(2分)【武汉交通科技大学1996 一、1(4分)】4.一个算法应该是(B )。【中山大学1998 二、1(2分)】 A.程序B.问题求解步骤的描述 C.要满足五个基本特性D.A和C. 5.下面关于算法说法错误的是( D )【南京理工大学2000 一、1(1.5分)】A.算法最终必须由计算机程序实现 B.为解决某问题的算法同为该问题编写的程序含义是相同的 C. 算法的可行性是指指令不能有二义性 D. 以上几个都是错误的 6. 下面说法错误的是(C )【南京理工大学2000 一、2 (1.5分)】 (1)算法原地工作的含义是指不需要任何额外的辅助空间 (2)在相同的规模n下,复杂度O(n)的算法在时间上总是优于复杂度O(2n)的算法(3)所谓时间复杂度是指最坏情况下,估算算法执行时间的一个上界 (4)同一个算法,实现语言的级别越高,执行效率就越低 A.(1) B.(1),(2) C.(1),(4) D.(3) 7.从逻辑上可以把数据结构分为( C )两大类。【武汉交通科技大学1996 一、4(2分)】 A.动态结构、静态结构B.顺序结构、链式结构 C.线性结构、非线性结构D.初等结构、构造型结构 8.以下与数据的存储结构无关的术语是( D )。【北方交通大学2000 二、1(2分)】A.循环队列 B. 链表 C. 哈希表 D. 栈 9.以下数据结构中,哪一个是线性结构( D )?【北方交通大学2001 一、1(2分)】 A.广义表 B. 二叉树 C. 稀疏矩阵 D. 串 10.以下那一个术语与数据的存储结构无关?(A)【北方交通大学2001 一、2(2分)】 A.栈 B. 哈希表 C. 线索树 D. 双向链表 11.在下面的程序段中,对x的赋值语句的频度为(C)【北京工商大学2001 一、10(3分)】 FOR i:=1 TO n DO

数据结构习题和答案及解析

第 1 章绪论 课后习题讲解 1. 填空 ⑴()是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。 【解答】数据元素 ⑵()是数据的最小单位,()是讨论数据结构时涉及的最小数据单位。 【解答】数据项,数据元素 【分析】数据结构指的是数据元素以及数据元素之间的关系。 ⑶从逻辑关系上讲,数据结构主要分为()、()、()和()。 【解答】集合,线性结构,树结构,图结构 ⑷数据的存储结构主要有()和()两种基本方法,不论哪种存储结构,都要存储两方面的内容:()和()。 【解答】顺序存储结构,链接存储结构,数据元素,数据元素之间的关系 ⑸算法具有五个特性,分别是()、()、()、()、()。 【解答】有零个或多个输入,有一个或多个输出,有穷性,确定性,可行性 ⑹算法的描述方法通常有()、()、()和()四种,其中,()被称为算法语言。 【解答】自然语言,程序设计语言,流程图,伪代码,伪代码 ⑺在一般情况下,一个算法的时间复杂度是()的函数。 【解答】问题规模 ⑻设待处理问题的规模为n,若一个算法的时间复杂度为一个常数,则表示成数量级的形式为(),若为n*log25n,则表示成数量级的形式为()。 【解答】Ο(1),Ο(nlog2n) 【分析】用大O记号表示算法的时间复杂度,需要将低次幂去掉,将最高次幂的系数去掉。 2. 选择题 ⑴顺序存储结构中数据元素之间的逻辑关系是由()表示的,链接存储结构中的数据元素之间的逻辑关系是由()表示的。 A 线性结构 B 非线性结构 C 存储位置 D 指针 【解答】C,D 【分析】顺序存储结构就是用一维数组存储数据结构中的数据元素,其逻辑关系由存储位置(即元素在数组中的下标)表示;链接存储结构中一个数据元素对应链表中的一个结点,元素之间的逻辑关系由结点中的指针表示。

数据结构与算法设计课后习题及答案详解

数据结构与算法设计课后习题及答案详解 1. 习题一:数组求和 题目描述:给定一个整数数组,编写一个函数来计算它的所有元素之和。 解题思路:遍历数组,将每个元素累加到一个变量中,最后返回累加和。 代码实现: ```python def sum_array(arr): result = 0 for num in arr: result += num return result ``` 2. 习题二:链表反转 题目描述:给定一个单链表,反转它的节点顺序。 解题思路:采用三指针法,依次将当前节点的下一个节点指向上一个节点,然后更新三个指针的位置,直到链表反转完毕。 代码实现:

```python class ListNode: def __init__(self, val=0, next=None): self.val = val self.next = next def reverse_list(head): prev = None curr = head while curr: next_node = curr.next curr.next = prev prev = curr curr = next_node return prev ``` 3. 习题三:二叉树的层序遍历 题目描述:给定一个二叉树,返回其节点值的层序遍历结果。 解题思路:采用队列来实现层序遍历,先将根节点入队,然后循环出队并访问出队节点的值,同时将出队节点的左右子节点入队。

代码实现: ```python class TreeNode: def __init__(self, val=0, left=None, right=None): self.val = val self.left = left self.right = right def level_order(root): if not root: return [] result = [] queue = [root] while queue: level = [] for _ in range(len(queue)): node = queue.pop(0) level.append(node.val) if node.left: queue.append(node.left)

数据结构习题参考答案与解析

习题1 参考答案 1至8题答案略。 9.(1)【解】该逻辑结构为线性结构,其图形表示如下: (2)【解】该逻辑结构为树型结构,其图形表示如下: (3)【解】该逻辑结构为图型结构,其图形表示如下: (4)【解】该逻辑结构为线性结构,其图形表示如下: 10.【解】该图书库存管理系统所要处理的数据对象为图书,所以该问题中涉及的数据元素为图书,设数据元素类型为bookType 类型。每个数据元素应包含的数据项有图书编号、书名、作者、出版社、出版日期等。可用一个表格(如下表)的形式表示图书间的逻辑关系,即该问题数学模型可采用简单的线性结构来表示。 根据问题需求功能目标,此模型的所需的主要处理操作有插入、删除、查找和修改等基本操作。 所以,现用抽象数据类型bookList 表示问题模型,其逻辑结构与基本操作的定义如下: (1)逻辑结构 bookList=( D, {r} ) D={b i | b i 为bookType 类型的元素,i=1,2,3, ....., n ,n ≥0} r ={ | i=1,2,…, n -1, n ≥0 } (2)基本操作 ①初始化 操作函数:InitBookList(&BL)。 ……

初始条件:图书表BL 不存在。 操作结果:构造一个空的图书表BL 。 ②求图书表长度 操作函数:bookListLength(BL)。 初始条件:图书表BL 已存在。 操作结果:返回图书表BL 中所包含的数据元素(图书)的个数。 ③取图书表中元素 操作函数:getBook(BL, i, &b)。 初始条件:图书表BL 已存在,且1≤i ≤bookListLength(BL)。 操作结果:用b 返回图书表BL 中的第i 个数据元素的值。 ④按编号查找 操作函数:locateById(BL, id)。 初始条件:图书表BL 已存在,id 是给定的一个图书编号。 操作结果:返回图书表BL 中图书编号为id 的数据元素的位序,若这样的数据元素不存在,则返回0。 ⑤按编号查找 操作函数:locateByName(BL, i, name)。 初始条件:图书表BL 已存在,且1≤i ≤bookListLength(BL),name 是给定的一个图书名。 操作结果:从图书表BL 中第i 个元素开始,查找图书名与给定name 相等的第一个元素,若找到则返回其位序,否则返回0。 ⑥插入图书 操作函数:insertBook(&BL, i, b)。 初始条件:图书表BL 已存在,且1≤i ≤bookListLength(BL)+1。 操作结果:在图书表BL 的第i 个位置上插入一个值为b 的新元素,使线性表的长度增1。 ⑦删除操作 操作函数:deleteBook(&BL, i, &b)。 初始条件:线性表L 已存在,1≤i ≤listLength(L)。 操作结果:删除图书表BL 的第i 个数据元素,并用b 返回其值,使线性表的长度减1。 11. (1)【解】函数体内为简单语句,时间复杂度为T(n)=O(1) (2)【解】选取的基本语句为“if(a[i]>a[k]) k=i;”其执行频度为n-1,时间复杂度为T(n)=O(n)。 (3)【解】选取的基本语句为最内层的循环体语句“total+=a[i][j];”,其执行频度为n(n+1)/2, 时间复杂度为T(n)=O(n 2 )。 (4)【解】选取的基本语句为最内层的循环体语句“c[i][j]+=a[i][k]*b[k][j];”,其执行 频度为n 3,时间复杂度为T(n)=O(n 3 )。 (5)【解】函数有两个并列的循环,其问题规模分别为n 和m ,对于第一个for 循环选取的基本语句为“if(a[i]>a[max]) max=i;”,其执行频度为n-1;对于第二个for 循环选取的基本语句为“if(b[i]

数据结构试题集[包含答案_完整版]

第一章概论 一、选择题 1、研究数据结构就是研究(D )。 A. 数据的逻辑结构 B. 数据的存储结构 C. 数据的逻辑结构和存储结构 D. 数据的逻辑结构、存储结构及其基本操作 2、算法分析的两个主要方面是( A )。 A. 空间复杂度和时间复杂度 B. 正确性和简单性 C. 可读性和文档性 D. 数据复杂性和程序复杂性 3、具有线性结构的数据结构是( D )。 A. 图 B. 树 C. 广义表 D. 栈 4、计算机中的算法指的是解决某一个问题的有限运算序列,它必须具备输入、输出、(B )等5个特性。 A. 可执行性、可移植性和可扩充性 B. 可执行性、有穷性和确定性 C. 确定性、有穷性和稳定性 D. 易读性、稳定性和确定性 5、下面程序段的时间复杂度是( C )。 for(i=0;i

A. 计算机程序 B. 解决问题的计算方法 C. 排序算法 D. 解决问题的有限运算序列 7、某算法的语句执行频度为(3n+nlog 2n+n 2+8),其时间复杂度表示( C )。 A. O(n) B. O(nlog 2n) C. O(n 2) D. O(log 2n) 8、下面程序段的时间复杂度为( C )。 i=1; while(i<=n) i=i*3; A. O(n) B. O(3n) C. O(log 3n) D. O(n 3) 9、数据结构是一门研究非数值计算的程序设计问题中计算机的数据元素以及它们之间的( B )和运算等的学科。 A. 结构 B. 关系 C. 运算 D. 算法 10、下面程序段的时间复杂度是(A )。 i=s=0; while(s

数据结构习题(包含全部答案解析)

数据结构习题集(自编) 第一章绪论 一、选择题 1.数据结构是一门研究非数值计算的程序设计问题中的操作对象以及它们之间的()和运算的学科。 A.结构B.关系 C.运算 D.算法 2.在数据结构中,从逻辑上可以把数据结构分成()。 A.动态结构和静态结构 B.紧凑结构和非紧凑结构 C.线性结构和非线性结构 D.逻辑结构和存储结构 3.线性表的逻辑顺序和存储顺序总是一致的,这种说法()。 A.正确B.不正确 C.无法确定 D.以上答案都不对4.算法分析的目的是()。 A.找出算法的合理性 B.研究算法的输人与输出关系 C.分析算法的有效性以求改进 D.分析算法的易懂性 5. 算法的时间复杂度取决于() A.问题的规模B待处理数据的初态 C. A和B 6.一个算法应该是()。 A.程序B.问题求解步骤的描述 C.要满足五个基本特性 D.A和C. 7. 下面关于算法说法错误的是() A.算法最终必须由计算机程序实现 B.为解决某问题的算法与为该问题编写的程序含义是相同的 C. 算法的可行性是指指令不能有二义性 D. 以上几个都是错误的 8.以下与数据的存储结构无关的术语是()。 A.循环队列 B. 链表 C. 哈希表 D. 栈 9.在下面的程序段中,对x的赋值语句的频度为() for(i=0;i

(完整版)数据结构课后习题答案

第1章绪论 1 ?简述下列概念:数据、数据元素、数据项、数据对象、数据结构、逻辑结构、存储结构、抽象数据类型。 答案: 数据:是客观事物的符号表示,指所有能输入到计算机中并被计算机程序处理的符号的总称。如数学计算中用到的整数和实数,文本编辑所用到的字符串,多媒体程序处理的图形、 图像、声音、动画等通过特殊编码定义后的数据。 数据元素:是数据的基本单位,在计算机中通常作为一个整体进行考虑和处理。在有些情况下,数据元素也称为元素、结点、记录等。数据元素用于完整地描述一个对象,如一个学生记录,树中棋盘的一个格局(状态)、图中的一个顶点等。 数据项:是组成数据元素的、有独立含义的、不可分割的最小单位。例如,学生基本信息表中的学号、姓名、性别等都是数据项。 数据对象:是性质相同的数据元素的集合,是数据的一个子集。例如:整数数据对象是集合N={0,士1,士2,…},字母字符数据对象是集合C={ ‘ A', ‘ B…,‘ Z,‘ a 'b ',…,‘ z ' },学生基本信息表也可是一个数据对象。 数据结构:是相互之间存在一种或多种特定关系的数据元素的集合。换句话说,数据结构是带“结构”的数据元素的集合,“结构”就是指数据元素之间存在的关系。 逻辑结构:从逻辑关系上描述数据,它与数据的存储无关,是独立于计算机的。因此,数据的逻辑结构可以看作是从具体问题抽象出来的数学模型。 存储结构:数据对象在计算机中的存储表示,也称为物理结构。 抽象数据类型:由用户定义的,表示应用问题的数学模型,以及定义在这个模型上的一组操作的总称。具体包括三部分:数据对象、数据对象上关系的集合和对数据对象的基本操作的集合。 2 ?试举一个数据结构的例子,叙述其逻辑结构和存储结构两方面的含义和相互关系。 答案: 例如有一张学生基本信息表,包括学生的学号、姓名、性别、籍贯、专业等。每个学生基本信息记录对应一个数据元素,学生记录按顺序号排列,形成了学生基本信息记录的线性序列。对于整个表来说,只有一个开始结点(它的前面无记录)和一个终端结点(它的后面无记 录),其他的结点则各有一个也只有一个直接前趋和直接后继。学生记录之间的这种关系就确 定了学生表的逻辑结构,即线性结构。 这些学生记录在计算机中的存储表示就是存储结构。如果用连续的存储单元(如用数组表示)来存放这些记录,则称为顺序存储结构;如果存储单元不连续,而是随机存放各个记录,然后用指针进行链接,则称为链式存储结构。 即相同的逻辑结构,可以对应不同的存储结构。 3 ?简述逻辑结构的四种基本关系并画岀它们的关系图。

《数据结构》教材课后习题+答案

《数据结构》教材课后习题+答案数据结构 第一章介绍 数据结构是计算机科学中重要的概念,它涉及到组织和存储数据的方法和技术。数据结构的选择对于算法的效率有着重要的影响。本教材为读者提供了丰富的课后习题,以帮助读者巩固所学知识并提高解决问题的能力。下面是一些选定的习题及其答案,供读者参考。 第二章线性表 习题一: 给定一个顺序表L,编写一个算法,实现将其中元素逆置的功能。 答案一: 算法思路: 1. 初始化两个指针i和j,分别指向线性表L的首尾两个元素 2. 对于L中的每一个元素,通过交换i和j所指向的元素,将元素逆置 3. 当i>=j时,停止逆置 算法实现: ```python

def reverse_list(L): i, j = 0, len(L)-1 while i < j: L[i], L[j] = L[j], L[i] i += 1 j -= 1 ``` 习题二: 给定两个线性表A和B,编写一个算法,将线性表B中的元素按顺序插入到线性表A中。 答案二: 算法思路: 1. 遍历线性表B中的每一个元素 2. 将B中的元素依次插入到A的末尾 算法实现: ```python def merge_lists(A, B): for element in B: A.append(element)

``` 第三章栈和队列 习题一: 编写一个算法,判断一个表达式中的括号是否匹配。表达式中的括号包括小括号"()"、中括号"[]"和大括号"{}"。 答案一: 算法思路: 1. 遍历表达式中的每一个字符 2. 当遇到左括号时,将其推入栈中 3. 当遇到右括号时,判断栈顶元素是否与其匹配 4. 当遇到其他字符时,继续遍历下一个字符 5. 最后判断栈是否为空,若为空则表示括号匹配 算法实现: ```python def is_matching(expression): stack = [] for char in expression: if char in "([{":

数据结构练习试题和答案解析

第1章绪论 一、判断题 1.数据的逻辑结构与数据元素本身的内容和形式无关。(√) 2.一个数据结构是由一个逻辑结构和这个逻辑结构上的一个基本运算集构成的整体。(√) 3.数据元素是数据的最小单位。(×) 4.数据的逻辑结构和数据的存储结构是相同的。(×) 5.程序和算法原则上没有区别,所以在讨论数据结构时可以通用。(×) 6.从逻辑关系上讲,数据结构主要分为线性结构和非线性结构两类。(√) 7.数据的存储结构是数据的逻辑结构的存储映象。(√) 8.数据的物理结构是指数据在计算机内实际的存储形式。(√) 9.数据的逻辑结构是依赖于计算机的。(×) 10.算法是对解题方法和步骤的描述。(√) 二、填空题 1.数据有逻辑结构和存储结构两种结构。 2.数据逻辑结构除了集合以外,还包括线性结构、树形结构和图形结构。 3.数据结构按逻辑结构可分为两大类,它们是线性结构和非线性结构。 4.树形结构和图形结构合称为非线性结构。 5.在树形结构中,除了树根结点以外,其余每个结点只有1个前驱结点。 6.在图形结构中,每个结点的前驱结点数和后继结点数可以任意多个。 7.数据的存储结构又叫物理结构。 8.数据的存储结构形式包括顺序存储、链式存储、索引存储和散列存储。 9.线性结构中的元素之间存在一对一的关系。 10.树形结构中的元素之间存在一对多的关系。 11.图形结构的元素之间存在多对多的关系。 12.数据结构主要研究数据的逻辑结构、存储结构和算法(或运算) 3个方面的内容。 13.数据结构被定义为(D,R),其中D是数据的有限集合,R是D上的关系有限集合。 14.算法是一个有穷指令的集合。 15.算法效率的度量可以分为事先估算法和事后统计法。 16.一个算法的时间复杂度是算法输入规模的函数。 17.算法的空间复杂度是指该算法所耗费的存储空间,它是该算法求解问题规模的n的函数。 18.若一个算法中的语句频度之和为T(n)=6n+3nlog2n,则算法的时间复杂度为O( nlog2n)。 19.若一个算法的语句频度之和为T(n)=3n+nlog2+n2,则算法的时间复杂度为O(n2)。 20.数据结构是一门研究非数值计算的程序问题中计算机的操作对象,以及它们之间的关系和运算的学 科。 三、选择题 1.数据结构通常是研究数据的(A)及它们之间的相互关系。 A.存储结构和逻辑结构 B.存储和抽象 C.联系和抽象 D.联系与逻辑 2.在逻辑上可以把数据结构分成(C)。 A.动态结构和静态结构 B.紧凑结构和非紧凑结构 C.线性结构和非线性结构 D.内部结构和外部结构。 3.数据在计算机存储内表示时,物理地址和逻辑地址相同并且是连续的,称之为(C)。 A.存储结构 B.逻辑结构 C.顺序存储结构 D.链式存储结构 4.非线性结构中的每个结点(D)。 A.无直接前驱结点. B.无直接后继结点.

严蔚敏版数据结构课后习题集答案解析~完整版

第1章绪论 1.1 简述下列术语:数据,数据元素、数据对象、数据结构、存储结构、数据类型和抽象数据类型。 解:数据是对客观事物的符号表示。在计算机科学中是指所有能输入到计算机中并被计算机程序处理的符号的总称。 数据元素是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。 数据对象是性质相同的数据元素的集合,是数据的一个子集。 数据结构是相互之间存在一种或多种特定关系的数据元素的集合。 存储结构是数据结构在计算机中的表示。 数据类型是一个值的集合和定义在这个值集上的一组操作的总称。 抽象数据类型是指一个数学模型以及定义在该模型上的一组操作。是对一般数据类型的扩展。 1.2 试描述数据结构和抽象数据类型的概念与程序设计语言中数据类型概念的区别。 解:抽象数据类型包含一般数据类型的概念,但含义比一般数据类型更广、更抽象。一般数据类型由具体语言系统内部定义,直接提供给编程者定义用户数据,因此称它们为预定义数据类型。抽象数据

类型通常由编程者定义,包括定义它所使用的数据和在这些数据上所进行的操作。在定义抽象数据类型中的数据部分和操作部分时,要求只定义到数据的逻辑结构和操作说明,不考虑数据的存储结构和操作的具体实现,这样抽象层次更高,更能为其他用户提供良好的使用接口。 1.3 设有数据结构(D,R),其中 {}4,3,2,1d d d d D =,{}r R =,()()(){}4,3,3,2,2,1d d d d d d r = 试按图论中图的画法惯例画出其逻辑结构图。 解: 1.4 试仿照三元组的抽象数据类型分别写出抽象数据类型复数和有理数的定义(有理数是其分子、分母均为自然数且分母不为零的分数)。 解: ADT Complex{ 数据对象:D={r,i|r,i 为实数} 数据关系:R={} 基本操作: InitComplex(&C,re,im) 操作结果:构造一个复数C ,其实部和虚部分别为re 和im DestroyCmoplex(&C)

数据结构各章习题及答案!

数据结构习题及解答 第1章 概述 【例1-1】分析以下程序段的时间复杂度。 for(i=0;i

log) 得:T(n)=O(n2 【例1-4】有如下递归函数fact(n),分析其时间复杂度。 fact(int n) { if(n<=1) return(1);① else return(n*fact(n-1));② } 解:设fact(n)的运行时间函数是T(n)。该函数中语句①的运行时间是O(1),语句②的运行时间是T(n-1)+ O(1),其中O(1)为常量运行时间。 由此可得fact(n)的时间复杂度为O(n)。 习题1 一、单项选择题 1.数据结构是指(1. A )。 A.数据元素的组织形式 B.数据类型 C.数据存储结构 D.数据定义 2.数据在计算机存储器内表示时,物理地址与逻辑地址不相同的,称之为(2. C )。 A.存储结构 B.逻辑结构 C.链式存储结构 D.顺序存储结构 3.树形结构是数据元素之间存在一种(3. D )。 A.一对一关系 B.多对多关系 C.多对一关系 D.一对多关系 4.设语句x++的时间是单位时间,则以下语句的时间复杂度为(4. B)。 for(i=1; i<=n; i++) for(j=i; j<=n; j++) x++; A.O(1) B.O(2n) C.O(n) D.O(3n) 5.算法分析的目的是(5. C、),算法分析的两个主要方面是(A)。 (1) A.找出数据结构的合理性 B.研究算法中的输入和输出关系 C.分析算法的效率以求改进 D.分析算法的易懂性和文档性 (2) A.空间复杂度和时间复杂度 B.正确性和简明性 C.可读性和文档性 D.数据复杂性和程序复杂性 6.计算机算法指的是(6. C、),它具备输入,输出和(B)等五个特性。 (1) A.计算方法 B.排序方法 C.解决问题的有限运算序列 D.调度方法 (2) A.可行性,可移植性和可扩充性 B.可行性,确定性和有穷性 C.确定性,有穷性和稳定性 D.易读性,稳定性和安全性 7.数据在计算机内有链式和顺序两种存储方式,在存储空间使用的灵活性上,链式存储比顺序存储要(7. B)。

数据结构试题及答案(十套)

数据结构试题及答案(十套)数据结构试题及答案(十套) 一、选择题 1. 数据结构是指()。 A. 存储数据的方式 B. 数据的逻辑结构和物理结构 C. 数据的存储结构和存储方式 D. 数据的逻辑结构、存储结构和存储方式 答案:D 2. 在数据结构中,线性表的存储方式包括()。 A. 顺序存储和链式存储 B. 数组存储和链表存储 C. 顺序存储、链表存储和索引存储 D. 顺序存储、链表存储和树形存储 答案:A 3. 栈是一种()的数据结构。 A. 先进先出

B. 先进后出 C. 后进先出 D. 后进后出 答案:C 4. 队列是一种()的数据结构。 A. 先进先出 B. 先进后出 C. 后进先出 D. 后进后出 答案:A 5. 二叉树中,度为0的节点称为()。 A. 叶子节点 B. 根节点 C. 中间节点 D. 子节点 答案:A 6. 以下哪个排序算法是稳定的?

A. 快速排序 B. 选择排序 C. 插入排序 D. 希尔排序 答案:C 7. 图中表示顶点之间关系的边的数量称为()。 A. 顶点度数 B. 边数 C. 路径数 D. 网络 答案:B 8. 哈希表通过()来实现高效的查找操作。 A. 散列函数 B. 排序算法 C. 遍历操作 D. 顺序存储 答案:A

9. 平衡二叉树是一种具有左右子树高度差不超过()的二叉树。 A. 0 B. 1 C. 2 D. 3 答案:B 10. 在链表中,删除节点的操作时间复杂度是()。 A. O(1) B. O(logn) C. O(n) D. O(nlogn) 答案:A 二、填空题 1. 在顺序存储结构中,元素之间的逻辑关系由()表示。 答案:下标 2. 二叉查找树的中序遍历结果是一个()序列。 答案:递增 3. 哈希表通过散列函数将关键字映射到()上。

数据结构期末真题答案解析

数据结构期末真题答案解析 作为计算机科学与技术专业的学生,数据结构是我们必修课程中 非常重要的一门。在期末考试中,通常会有一些较为复杂的问题需要 我们解答。本文将对一些典型的数据结构期末真题进行解析,帮助大 家更好地理解和掌握这门课程。 1. 题目一:给定一个无序数组,如何在最高效的时间复杂度下 找到数组中的最大值和最小值? 这道题考察的是搜索算法中的最值问题。我们可以使用线性扫描 的方法来解决。依次遍历数组的每个元素,更新最大值和最小值的变量,最后输出即可。这种方法的时间复杂度为O(n),其中n是数组的 长度。 2. 题目二:如何实现一个栈,使得在常数时间内获取栈中的最 小元素? 这道题考察了栈和数据结构设计。我们可以使用一个辅助栈来解决。辅助栈的作用是记录栈中当前的最小元素。具体的实现方法是, 在每次入栈时,比较新元素与辅助栈中的栈顶元素的大小,将较小的 元素入辅助栈。这样,辅助栈的栈顶元素始终是当前栈中的最小元素。时间复杂度为O(1)。 3. 题目三:给定一个有向图,如何判断其中是否存在环? 这道题考察了图的遍历和拓扑排序。我们可以使用深度优先搜索(DFS)的方法来解决。从图中的任意一个节点出发进行深度优先遍历,如果在遍历的过程中发现存在某个节点被遍历了两次,则说明存在环。

时间复杂度为O(V + E),其中V是图中的节点数,E是边的数量。 4. 题目四:给定一个字符串,如何判断其中是否存在重复字符? 这道题考察了字符串的处理和哈希表的运用。我们可以使用一个 哈希表来记录字符串中每个字符的出现次数,然后遍历哈希表,判断 是否存在出现次数大于1的字符。时间复杂度为O(n),其中n是字符 串的长度。 总结:通过解析以上几道典型的数据结构期末真题,我们可以看 出在实际问题中,数据结构的运用非常广泛。掌握了各种数据结构的 原理和相关算法,有助于我们在实际工作中更高效地解决问题。因此,我们应该注重理论学习和实践运用的结合,提高数据结构的应用能力。 另外,在应对期末考试时,我们要多做真题练习,理解题目的意 图和解决思路,熟悉常见的数据结构和算法,灵活运用所学知识解决 问题。同时,我们也要学会总结和归纳,将不同的知识点和算法联系 起来,形成系统性的学习框架。 希望以上对几道数据结构期末真题的解析能够对大家有所帮助, 祝愿大家在期末考试中取得好成绩!

数据结构上机例题及答案

习题二 ⒉1描述以下四个概念的区别:头指针变量,头指针,头结点,首结点(第一个结点)。解:头指针变量和头指针是指向链表中第一个结点(头结点或首结点)的指针;在首结点之前附设一个结点称为头结点;首结点是指链表中存储线性表中第一个数据元素的结点。若单链表中附设头结点,则不管线性表是否为空,头指针均不为空,否则表示空表的链表的头指针为空。 2.2简述线性表的两种存储结构有哪些主要优缺点及各自使用的场合。 解:顺序存储是按索引直接存储数据元素,方便灵活,效率高,但插入、删除操作将引起元素移动,降低了效率;而链式存储的元素存储采用动态分配,利用率高,但须增设表示结点之间有序关系的指针域,存取数据元素不如顺序存储方便,但结点的插入和删除十分简单。顺序存储适用于线性表中元素数量基本稳定,且很少进行插入和删除,但要求以最快的速度存取线性表中的元素的情况;而链式存储适用于频繁进行元素动态插入或删除操作的场合。 2.3 在头结点为h的单链表中,把值为b的结点s插入到值为a的结点之前,若不存在a,就把结点s插入到表尾。 Void insert(Lnode *h,int a,int b) {Lnode *p,*q,*s; s=(Lnode*)malloc(sizeof(Lnode)); s->data=b; p=h->next; while(p->data!=a&&p->next!=NULL) {q=p; p=p->next; } if (p->data==a) {q->next=s; s->next=p;} else

{p->next=s; s->next=NULL; } } 2.4 设计一个算法将一个带头结点的单链表A分解成两个带头结点的单链表A和B,使A中含有原链表中序号为奇数的元素,而B中含有原链表中序号为偶数的元素,并且保持元素原有的相对顺序。 Lnode *cf(Lnode *ha) {Lnode *p,*q,*s,*hb; int t; p=ha->next; q=ha; t=0; hb=(Lnode*)malloc(sizeof(Lnode)); s=hb; while(p->next!=NULL) {if (t==0) {q=p;p=p->next;t=1;} else {q->next=p->next; p->next=s->next; s->next=p; s=p; p=p->next; t=0; } } s->next=NULL; return (hb); }

数据结构教程,含习题和答案

第一章:概论(包括习题与答案及要点) 本章的重点是了解数据结构的逻辑结构、存储结构、数据的运算三方面的概念及相互关系,难点是算法复杂度的分析方法。 需要达到<识记>层次的基本概念和术语有:数据、数据元素、数据项、数据结构。特别是数据结构的逻辑结构、存储结构及数据运算的含义及其相互关系。数据结构的两大类逻辑结构和四种常用的存储表示方法。 需要达到<领会>层次的内容有算法、算法的时间复杂度和空间复杂度、最坏的和平均时间复杂度等概念,算法描述和算法分析的方法、对一般的算法要能分析出时间复杂度。 -------------------------------------------------------------------------------- 对于基本概念,仔细看书就能够理解,这里简单提一下: 数据就是指能够被计算机识别、存储和加工处理的信息的载体。 数据元素是数据的基本单位,有时一个数据元素可以由若干个数据项组成。数据项是具有独立含义的最小标识单位。如整数这个集合中,10这个数就可称是一个数据元素.又比如在一个数据库(关系式数据库)中,一个记录可称为一个数据元素,而这个元素中的某一字段就是一个数据项。 数据结构的定义虽然没有标准,但是它包括以下三方面内容:逻辑结构、存储结构、和对数据的操作。这一段比较重要,我用自己的语言来说明一下,大家看看是不是这样。 比如一个表(数据库),我们就称它为一个数据结构,它由很多记录(数据元素)组成,每个元素又包括很多字段(数据项)组成。那么这张表的逻辑结构是怎么样的呢? 我们分析数据结构都是从结点(其实也就是元素、记录、顶点,虽然在各种情况下所用名字不同,但说的是同一个东东)之间的关系来分析的,对于这个表中的任一个记录(结点),它只有一个直接前趋,只有一个直接后继(前趋后继就是前相邻后相邻的意思),整个表只有一个开始结点和一个终端结点,那我们知道了这些关系就能明白这个表的逻辑结构了。 而存储结构则是指用计算机语言如何表示结点之间的这种关系。如上面的表,在计算机语言中描述为连续存放在一片内存单元中,还是随机的存放在内存中再用指针把它们链接在一起,这两种表示法就成为两种不同的存储结构。(注意,在本课程里,我们只在高级语言的层次上讨论存储结构。) 第三个概念就是对数据的运算,比如一张表格,我们需要进行查找,增加,修改,删除记录等工作,而怎么样才能进行这样的操作呢? 这也就是数据的运算,它不仅仅是加减乘除这些算术运算了,在数据结构中,这些运算常常涉及算法问题。

数据结构期末复习题及部分答案解析

一.是非题 1. 数据结构(应该是抽象数据类型)可用三元式表示(D,S,P)。其中:D是数据对象,S 是D上的关系,P是对 D的基本操作集。(f) 2 简单地说,数据结构是带有结构的数据元素的集合。(t) 3 判断带头结点的非空循环单链表(头指针为L)中指针p所指结点是最后一个元素结点 的条件是:p->next==L。(t) 4 线性表的链式存储结构具有可直接存取?表中任一元素的优点。(f) 5 线性表的顺序存储结构优于链式存储结构。(f) 6. 在单链表P指针所指结点之后插入S结点的操作是: P->next= S ; S-> next = P->next;。(顺序弄反了)(f) 7 对于插入、删除而言,线性表的链式存储优于顺序存储。(t) 8. 顺序存储方式的优点是存储密度大,且插入、删除运算效率高。(f) 9. 栈和队列是操作上受限制的线性表。(t) 10. 队列是与线性表完全不同的一种数据结构。栈和队列是操作上受限制的线性表(f) 11. 队列是一种操作受限的线性表,凡对数据元素的操作仅限一端进行。对列不是(f) 12. 栈和队列也是线性表。如果需要,可对它们中的任一元素进行操作。(f) 13. 栈是限定仅在表头进行插入和表尾进行删除运算的线性表。(f) 14. 二叉树中每个结点有两个子结点,而对一般的树,则无此限制,所以,二叉树是树的 特殊情形。(f) 15 二叉树是一棵结点的度最大为二的树二叉树和树相互独立。(f) 16 赫夫曼树中结点个数一定是奇数。(t) 17 在二叉树的中序遍历序列中,任意一个结点均处在其左孩子结点的后面。(t) 18 假设B是一棵树,B′是对应的二叉树。则B的后根遍历相当于B′的后序遍历后根遍历相当于中序遍历。(f) 19. 通常,二叉树的第i层上有2i-1个结点。应该为1~2i-1个(f) 20. 中序线索二叉树的优点是便于在中序下查找直接前驱结点和直接后继结点。(t) 21 二叉树的先序遍历序列中,任意一个结点均处在其孩子结点的前面。(t) 22 由树结点的先根序列和后根序列可以唯一地确定一棵树。 (t) 23 邻接多重表可以用以表示无向图,也可用以表示有向图。只能表示无向图,有向图用十字链表(f) 24 可从任意有向图中得到关于所有顶点的拓扑次序带环图没有。(f) 25 有向图的十字链表是将邻接表和逆邻接表合二为一的链表表示形式。(t) 26 关键路径是AOE网中源点到汇点的最短路径。(f) 27 连通图G的生成树是一个包含G的所有n个顶点和n-1条边的子图。(f) 28 一个无向图的连通分量是其极大的连通子图。(t) 29 十字链表可以表示无向图,也可用以表示有向图。(f) 30 邻接表可以表示有向图,也可以表示无向图。(t ) 31. 二叉排序树的平均查找长度为O(logn)。(t) 32. 二叉排序树的最大查找长度与(LOG2N)同阶。(f) 33 选用好的HASH函数可避免冲突。哈希函数有几种处理冲突的方法(f) 34 折半查找不适用于有序链表的查找。(t) 35. 对于目前所知的排序方法,快速排序具有最好的平均性能。(t) 36 对于任何待排序序列来说,快速排序均快于冒泡排序。(f)

(完整版)数据结构练习题及参考答案

数据结构练习题 第一部分绪论 一、单选题 1. 一个数组元素a[i]与________的表示等价。 A、 *(a+i) B、 a+i C、 *a+i D、 &a+i 2. 对于两个函数,若函数名相同,但只是____________不同则不是重载函数。 A、参数类型 B、参数个数 C、函数类型 3. 若需要利用形参直接访问实参,则应把形参变量说明为________参数 A、指针 B、引用 C、值 4. 下面程序段的时间复杂度为____________。 for(int i=0; i

相关文档
最新文档