数据结构习题和复习资料及解析.docx

上传人:b****1 文档编号:334799 上传时间:2022-10-09 格式:DOCX 页数:110 大小:485.83KB
下载 相关 举报
数据结构习题和复习资料及解析.docx_第1页
第1页 / 共110页
数据结构习题和复习资料及解析.docx_第2页
第2页 / 共110页
数据结构习题和复习资料及解析.docx_第3页
第3页 / 共110页
数据结构习题和复习资料及解析.docx_第4页
第4页 / 共110页
数据结构习题和复习资料及解析.docx_第5页
第5页 / 共110页
点击查看更多>>
下载资源
资源描述

数据结构习题和复习资料及解析.docx

《数据结构习题和复习资料及解析.docx》由会员分享,可在线阅读,更多相关《数据结构习题和复习资料及解析.docx(110页珍藏版)》请在冰豆网上搜索。

数据结构习题和复习资料及解析.docx

数据结构习题和复习资料及解析

第1章绪论

课后习题讲解

1.填空

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

【解答】数据元素

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

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

⑶从逻辑关系上讲,数据结构主要分为()、()、()和()。

【解答】集合,线性结构,树结构,图结构

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

()

和()。

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

⑸算法具有五个特性,分别是()、()、()、()、()。

【解答】有零个或多个输入,有一个或多个输出,有穷性,确定性,可行性

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

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

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

【解答】问题规模

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

为n*log25n,则表示成数量级的形式为()。

【解答】0

(1),O(nlog2n)

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

2.选择题

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

A线性结构B非线性结构C存储位置D指针

【解答】C,D

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

⑵假设有如下遗产继承规则:

丈夫和妻子可以相互继承遗产;子女可以继承父亲或母亲的遗产;子女间不

能相互继承。

则表示该遗产继承关系的最合适的数据结构应该是()。

A树B图C线性表D集合

【解答】B

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

團17逅产鮭承逻辑结枸團

⑶算法指的是()。

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

B计算机程序C解决问题的计算方法D数据处理

【解答】A

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

所以,只有A是算法的准确定义。

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

A有穷性B确切性C高效性D可行性

【解答】C

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

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

A找岀数据结构的合理性B研究算法中输入和输岀的关系

C分析算法的效率以求改进D分析算法的易读性和文档性

E空间性能和时间性能F正确性和简明性

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

【解答】C,E

3.判断题

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

【解答】错。

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

⑵每种数据结构都具备三个基本操作:

插入、删除和查找。

【解答】错。

如数组就没有插入和删除操作。

此题注意是每种数据结构。

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

【解答】错。

是数据之间的逻辑关系的整体。

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

【解答】对。

因此逻辑结构是数据组织的主要方面。

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

【解答】错。

基本操作的实现是基于某种存储结构设计的,因而不是唯一的

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

(1)出

C2)尸再k=0,

while

do

r

I

L

i卄i

}while(i<=n)

(3)

(4)y-0;

while^i-+j<=n)

while代?

+1严仗十Dsn)

ifMJj卄;

dsei+^;

farj十十)

for(T;k++)

【解答】⑴基本语句是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,即:

仃(n)+1)2

rcn)=zZxl=

⑸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.为整数定义一个抽象数据类型,包含整数的常见运算,每个运算对应一个基本操作,每个基本操作的接

口需定义前置条件、输入、功能、输岀和后置条件。

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

ADTinteger

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]设计一个排序算法。

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

AT对n个记录进行n-l趙简单选捋捷序I

y1.1在无序区[i,tri]中选取最小记录,设其下标次indeK:

V1.2播最中记录弓第1个记灵交换1

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

简笙选择扫卡序算廷「Se!

比诣ort[

5roidSdectSort.(mlr[],intn)

for(i=0;kh-1u^)录进行卷简单遶择排序

indcsE”

for(j=i+l;jvi,户再闪£无序区中选职盘小记录

if曲]

ifr[i]—班罰悶*胶换元素

 

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

ra-3M-1气

TW-sS1=

F・D>!

+i

 

 

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

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

M将前两个元素进行比较’较大看放到tn呕中,较小看顽到in皿中’

2.从第3个元素开始直到最后一个元素依谀取云素直[i],执行F列操作’2.1如臬直[Amaxi则A[i]为最大值'原来的最大值为次最大值;2.2否则f如果心冈匕011啓则歳大值不恋A[i]划欠最大值亍

3辐出匿大值tM理泱最大值timast;

算法的C++描述如下:

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

学习自测及答案

1•顺序存储结构的特点是(),链接存储结构的特点是()

【解答】用元素在存储器中的相对位置来表示数据元素之间的逻辑关系,用指示元素存储地址的指针表示

数据元素之间的逻辑关系

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

【解答】健壮性

3.常见的算法时间复杂度用大0记号表示为:

常数阶()、对数阶()、线性阶()、平方阶()和指数阶()

【解答】0

(1),0(Iog2n),0(n),0(n2),0(2n)

锻大值和次最知直算法[

void(iniA[],intn,int&max,int&nmax)

('

if(A[0]>-A[l]){

nma^=A[l]T

dse{

max-A[l];

r^mas?

=A[0]T

for(尸監L

if(

max^=A[i];

elseif(A[i]>fLmax)ninax=A(i];

cout«"最丈值ft最丈值"

ridl?

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

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

n2+log2n

【解答】Iog2n,n1/2+Iog2n,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)

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高中教育 > 语文

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1