数据结构与算法作业.docx

上传人:b****4 文档编号:12340568 上传时间:2023-04-18 格式:DOCX 页数:24 大小:254.34KB
下载 相关 举报
数据结构与算法作业.docx_第1页
第1页 / 共24页
数据结构与算法作业.docx_第2页
第2页 / 共24页
数据结构与算法作业.docx_第3页
第3页 / 共24页
数据结构与算法作业.docx_第4页
第4页 / 共24页
数据结构与算法作业.docx_第5页
第5页 / 共24页
点击查看更多>>
下载资源
资源描述

数据结构与算法作业.docx

《数据结构与算法作业.docx》由会员分享,可在线阅读,更多相关《数据结构与算法作业.docx(24页珍藏版)》请在冰豆网上搜索。

数据结构与算法作业.docx

数据结构与算法作业

《数据结构与算法》作业

说明:

1、题号形式:

每题都以【sn,cha,sec】开头,sn表明本题的题目序号,每道题都有唯一的序号;cha表示内容所在的章;sec表示内容所在的节。

如【17,2,1】表示序号17的题来自第2章第1节。

2、题型:

1)填空题:

1-80

2)分析计算作图题:

序号1-30题(选自《数据结构题集》—严蔚敏等编)

3、内容取舍:

根据本学期上课课件中的内容,未上课章节的练习可舍弃。

4、必做题或选做题:

第四章和第五章不考,所以可以选做。

1)填空题:

序号1-80题

【1,1,2】线性结构中元素之间存在一对一关系,树形结构中元素之间存在

 一对多   关系,图形结构中元素之间存在 多对多   关系。

【2,1,2】为了最快地存取数据元素,物理结构宜采用线性结构结构。

【3,1,2】数据结构的三要素是数据,数据元素,数据对象。

【4,1,2】数据的逻辑结构可形式地用一个二元组B=(K,R)来表示,其中K是数据元素的有限集__,R是K上关系的有限集___。

【5,1,2】存储结构可根据数据元素在机器中的位置是否一定连续分为顺序存储结构__,链式存储结构___。

【6,1,4】度量算法效率可通过依据该算法在编制的程序在计算机上运行时所消耗的时间__来进行。

【7,1,4】算法的五个重要特性是确定性、 有穷性 、 可行性 、输入和输出。

【8,1,4】设n为正整数,则下面程序段的时间复杂度是T(n)=O(n)__。

i=1;k=0;

while(i

{

k=k+10*i;i++;

}

【9,1,4】设n为正整数,下面程序段中前置以记号@的语句的频度是①。

for(i=0;i

for(j=0;j

if(i+j==n-1)

@a[i][j]=0;

}

【10,1,4】设n为正整数,试确定下列各程序段中前置以记号@的语句的频度:

(1)i=1;k=0;

while(i<=n-1){

i++;

@k+=10*i;//语句的频度是______________________。

}

(2)k=0;

for(i=1;i<=n;i++){

for(j=i;j<=n;j++)

@k++;//语句的频度是______________________。

}

【11,1,4】按增长率由大到小排列下列函数的结果是________________________________。

log2(log2n),nlog2n,n2,n1/2,log2n,n

【12,2,1】当线性表的规模比较大,难以估计其存储规模时,一般以采用文件的存储结构为好。

【13,2,1】线性表(a1,a2,…,an)有两种存储结构:

顺序存储结构和链式存储结构,请就这两种存储结构完成下列填充:

__顺序存储_存储密度较大;__链式存储__存储利用率较高;__链式存储__可以随机存取;__顺序存储___不可以随机存取;

__链式存储__插入和删除操作比较方便。

【14,2,2】从一个长度为n的顺序表中删除第i个元素(1≤i≤n)时,需向前移动n-i个元素。

【15,2,3】带头结点的双链表L为空的条件是L->next=L。

【16,2,3】带头结点的单链表Head为空的条件是____head→next==NULL______。

【17,2,3】非空单循环链表L中*p是尾结点的条件是____P!

=NULL__________。

【18,2,3】在一个单链表中p所指结点(p所指不是最后结点)之后插入一个由指针s所指结点,应执行s->next=__p->next___;和p->next=___S____的操作。

【19,2,3】在一个单链表中的指针p所指结点之前插入一个由指针s所指结点,可执行以下操作序列:

s->next=p->next____;

p->next=s;

t=p->data;

p->data=___s->data_____;

s->data=t;

【20,2,3】在一个单链表中删除p所指结点时,应执行以下操作:

q=p->next;

p->data=p->next->data;

p->next=q->next_;

free(q);

【21,2,3】在单链表中,删除指针P所指结点的后继结点的语句是p->next;p->next=p->next->next;__。

【22,2,3】带头结点的单循环链表Head的判空条件是__Head->Null___;不带头结点的单循环链表的判空条件是___②__。

 

【23,2,3】删除带头结点的单循环链表Head的第一个结点的操作是__①___;删除不带头结点的单循环链表的第一个结点的操作是__②___。

【24,2,3】已知L是带表头结点的非空单链表,且P结点既然不首元结点,也不是尾元结点,试从下列提供的答案中选择合适的语句序列。

a.删除P结点的直接前驱结点的语句序列是________________________________。

b.删除结点P的语句序列是________________________________。

c.删除尾元结点的语句序列是________________________________。

(1)P=P->next;

(2)P->next=P;

(3)P->next=P->next->next;

(4)P=P->next->next;

(5)while(P!

=NULL)P=P->next;

(6)while(Q->next!

=NULL){P=Q;Q=Q->next};

(7)while(P->next!

=Q)P=P->next;

(8)while(P->next->next!

=Q)P=P->next;

(9)while(P->next->next!

=NULL)P=P->next;

(10)Q=P;

(11)Q=P->next;

(12)P=L;

(13)L=L->next;

(14)free(Q);

【25,3,1】栈操作的原则是先进后出。

【26,3,1】对一个栈,给定输入的顺序是A、B、C,则全部不可能的输出序列有①。

【27,3,1】数据A、B、C、D依次进栈后,再从栈中取一数据,则它是D。

则本栈得到DCBA的输出序列,其理由是先进后出,进入的顺序是ABCD则出来的顺序为DCBA。

【28,3,1】.在栈顶指针为HS的链栈中,判定栈空的条件是        。

【29,3,1】将递归算法改写成等价的非递归算法,通常应该设置①的数据结构

【30,3,2】下列程序把十进制数转换为十六进制数,请填写合适的语句成分。

(每空2分)

voidconversion10_16()

{InitStack(&s);

scanf(“%d”,&N);

while(N){

1_____________________;

N=N/16;

}

while(!

StackEmpty(s)){

2_____________________;

if(e<=9)printf(“%d”,e);

elseprintf(“%c”,e-10+’A’);

}

}/*conversion*/

【31,3,4】若一个栈的输入序列为1,2,3,…,n,输出序列的第一个元素为n,则第i个输出元素是n-i+1。

【32,3,4】若用一个大小为6个元素的数组来实现循环队列,且当前rear=0和front=3。

当从队列中删除一个元素,再加入两个元素后,rear和front的值分别是①和②。

【33,3,4】已知一个栈的输入序列为1,2,3,…,n,输出序列为a1,a2,a3,…,an,那么a2=n的输出序列共有0种。

【34,3,4】堆栈和队列都是线性表,堆栈是____一种先进后出的线性表____的线性表,而队列是__是一种先进先出的_____________的线性表。

【35,3,4】从循环队列中删除一个元素时,其操作是           。

【36,3,4】若用一个大小为6个元素的数组来实现循环队列,且当前rear=0和front=3。

当从队列中删除一个元素,再加入两个元素后,rear和front的值分别是和。

【37,3,4】下面是关于循环队列的操作,请在划线空白处填写合适语句成分。

StatusEnQueue(SqQueue&Q,QelemTypee)

{

if((Q.rear=1)%MAXSIZE==q.fromt

)retrunERROR;

Q.base[(Q.rear+1)%MAXSIZE]=e;

Q.rear=(Q.rear+1)%MAXSIZE

;

returnOK;

}//EnQueue

【52,6,1】

已知一棵树边的集合是{,,,,,,,,}。

那么根结点是①,结点b的双亲是②,结点a的子孙有③,树的深度是④,树的度是⑤,结点g在树的第⑥层。

【53,6,2】通常使用         来表示二叉树结构。

【54,6,2】从概念上讲,树与二叉树是二种不同的数据结构,将树转化为二叉树的基本的目的是                         。

【55,6,2】在图1至图5中,__2、3、4、5______是树,___2、3、4__________是二叉树,____2、3__________是完全二叉树,_______3__________是满二叉树。

图1图2图3图4图5

【56,6,3】在图4中,结点H在这棵树的前序、中序和后序遍历次序中分别是_____、第__5___和第______个结点。

【57,6,2】满三叉树的第i层的结点个数为①,深度为h时该树中共有②结点。

【58,6,2】在图4中,A是______结点,D是______结点,B是E的________,B是G的________,D是E的________。

这棵树的度是________,深度是________。

【59,6,2】程序填空:

下列算法是求以二叉链表存储的二叉树中的最小值,设数据域的类型为int。

voidminnode(BiTreeT,int*min)

{

if(T!

=NULL)

{

if(①)*min=T->data;

minnode(T->lchild,min);

②;

}

}

【60,6,2】已知一棵完全二叉树有56个叶子结点,从上到下、从左到右对它的结点进行编号,根结点为1号。

则该完全二叉树总共结点有________个;有_______层;第91号结点的双亲结点是_______号;第63号结点的左孩子结点是_________号。

(每空2分)

【61,6,2】下列表示的图中,共有___5____个是树;有___3____个是二叉树;有___2____个是完全二叉树。

【62,6,3】下列二叉树的中序遍历序列是_DBNGOAEC__;后序遍历序列是______________________________________。

 

【63,6,3】一棵二叉树的中序遍历序列是DBNGOAEC,后序遍历序列是DNOGBECA,则其先序遍历的序列中的第一个元素是____,第五个元素是__,最后一个元素是__

【64,6,3】下列二叉树的先序遍历序列的第5个结点是______;第8个结点是_____;后序遍历序列的第2个结点是_____;第6个结点是_____。

(每空2分)

【65,6,3】如果某二叉树的后序遍历序列是ABCDEFGHI,中序遍历序列是ACBIDFEHG,则其先序遍历序列的第一个字母是①,最后一个字母是②。

【66,6,3】程序填空:

设算法DFS(Mgraph*G,inti)是无向图G从i顶点开始的深度优先遍历算法。

下列算法是判断无向图G是否是连通的。

intisconnect(Mgraph*G)

{inti,k=0;

for(i=0;ivexnum;i++)

visited[i]=0;

for(i=0;ivexnum;i++)

if(!

visited[i])

{①;

DFS(G,i);

}

if(k==1)②;

elsereturn0;

}

【67,7,2】图有①和②等存储结构。

【68,7,2】设无权图G的邻接矩阵为A,若(vi,vj)属于图G的边集合,则对应元素A[i][j]等于①,22、设无向图G的邻接矩阵为A,若A[i][j]等于0,则A[j][i]等于①。

【69,7,2】若一个图用邻接矩阵表示,则计算第i个结点的入度的方法是①。

【70,7,2】若一个图用邻接矩阵表示,则删除从第i个顶点出发的所有边的方法是①。

【71,7,4】n个顶点的连通图至少有①条边。

【72,7,4】设一个图

G={V,{A}},V={a,b,c,d,e,f},A={,,,,,,}。

那么顶点e的入度是①;出度是②;通过顶点f的简单回路有③条;就连通性而言,该图是④图;它的强连通分量有⑤个;其生成树可能的最大深度是⑥  。

【73,7,5】下面有向图共有_______个顶点;从v3到v2的最短简单路径之一是_________________;v1的出度是________;包含所有顶点的简单路径之一是_____________________。

【74,9,2】n个结点的二叉排序树的最大深度是①,最小深度为②

【75,9,3】设HASH表的大小为n(n=7),HASH函数为h(x)=x%n,如果用线性探测法F(i)=i解决冲突,请在下面HASH表中依次插入关键字5,18,21,14,25,4以后,关键字4、5和25所在地址的下标分别是、和,插入上述6个元素的平均比较次数是。

下标:

0 123456

【76,10,1】排序过程一般需经过两个基本操作,它们是①和②。

【77,10,2】结点的关键字序列是(F,B,J,G,E,A,I,D,C,H),对它按字母的字典序进行排列。

如果采用Shell排序方法,那么步长取5时,第一次扫描结果的前5个字母分别是②。

【78,10,2】在对一组关键字是(54,38,96,45,15,72,60,23,83)的记录进行直接插入排序时,当把第七个记录(关键字是60)插入到有序表时,为寻找插入位置需比较①次。

【79,10,3】在利用快速排序方法对一组关键字是(54,38,96,45,15,72,60,23,83)的记录进行排序时,需要递归调用partition函数,递归的最大深度(设第一次调用深度为1)为①,共需5次递归调用,其中第二次递归调用是对关键字是②的一组记录进行的。

【80,10,4】插入排序、希尔排序、选择排序、快速排序、堆排序、归并排序、和基数排序方法中,不稳定的排序方法有①。

2)分析计算作图题:

序号1-30(选自《数据结构题集》—严蔚敏等编)

【1,1,4】(选自《数据结构题集》1.8,选做题)

设n为正整数,试确定下列各段程序中前置以记号@的语句的频度(语句的频度指的是该语句重复执行的次数)。

(1)i=1;k=0;

while(i<=n-1){

i++;

@k+=10*i;

}

(2)x=91;y=100;

while(y>0){

@if(x>100){x-=10;y--;}

elsex++;

}

【2,1,4】(选自《数据结构题集》1.9,选做题)

假设n为2的乘幂,并且n>2,试求下列算法的时间复杂度及变量count的值(以n函数形式表示)

intTime(intn){

count=0;x=2;

while(x

x*=2;count++;

}

return(count);

}//Time

【3,2,3】(选自《数据结构题集》2.6,必做题)

已知L是无表头结点的单链表,且P既不是首元结点,也不是尾元结点,试从下列提供的答案中选择合适的语句序列。

a.在P结点后插入S结点的语句序列是____________________

b.在P结点前插入S结点的语句序列是____________________

c.在表首插入S结点的语句序列是________________________

d.在表尾插入S结点的语句序列是________________________

(1)P—>next=S;

(2)P—>next=P—>next—>next;

(3)P—>next=S—>next;

(4)S—>next=P—>next;

(5)S—>next=L;

(6)S—>next=NULL;

(7)Q=P;

(8)while(P—>next!

=Q)P=P—>next;

(9)while(P—>next!

=NULL)P=P—>next;

(10)P=Q;

(11)P=L;

(12)L=S;

(13)L=P;

【4,2,2】(选自《数据结构题集》2.10,选做题)

指出以下算法中的错误和低效(即费时)之处,并将它改写为一个既正确又高效的算法。

StatusDeleteK(SqList&a,inti,intk){

//本过程从顺序存储结构的线性表a中删除第i个元素起的k个元素

if(i<1||k<0||i+k>a.length)returnINFEASIBLE;//参数不合法

else{

for(count=1;count

//删除一个元素

for(j=a.length;j>=i+1;j――)a.elem[j-1]=a.elem[j];

a.length――;

}

returnOK;

}//DeleteK

【5,3,1】(选自《数据结构题集》3.4,必做题)

简述以下算法的功能(栈的元素类型SElemType为int)

(1)Statusalgo1(StackS){

inti,n,A[255];

n=0;

while(!

StackEmpty(S)){n++;Pop(S,A[n]);}

for(i=1;i<=n;i++)Push(S,A[i]);

}

(2)Statusalgo2(StackS,inte){

StackT;intd;

InitStack(T);

while(!

StackEmpty(S)){

Pop(S,d);

if(d!

=e)Push(T,d);

}

while(!

StackEmpty(T)){

Pop(T,d);

Push(S,d);

}

}

【6,3,1】(选自《数据结构题集》3.15,选做题)

假设以顺序存储结构实现一个双向栈,即在一堆数组的存储空间中存在着两个栈,它们的栈底分别设在数组的两个端点。

试编写实现这个双向栈tws的三个操作:

初始化inistack(tws)、入栈push(tws,i,x)和出栈pop(tws,i)的算法,其中i为0或1,用以分别指示设在数组两端的两个栈,并讨论按过程(正/误状态变量可设为变参)或函数设计这些操作算法各有什么优缺点。

【7,3,4】(选自《数据结构题集》3.13,必做题)

简述以下算法的功能(栈和队列的元素类型均为int)

voidalgo3(Queue&Q){

StackS;intd;

InitStack(S);

while(!

QueueEmpty(Q)){

DeQueue(Q,d);Push(S,d);

}

while(!

StackEmpty(S)){

Pop(S,d);EnQueue(Q,d);

}

}

【8,3,2】(选自《数据结构题集》3.19,选做题)

假设一个算术表达式中可以包含三种括号:

圆括号“(”和“)”,方括号“[”和“]”和花括号“{”和“}”,且这三种括号可以按任意的次序嵌套使用(如:

…[…{…}…[…]…]…[…]…(…)…)。

编写判别给定表达式所含括号是否正确配对出现的算法(已知表达式已存入数据元素为字符的顺序表中)。

【9,4,1】(选自《数据结构题集》4.3,必做题)

设s=‘IAMASTUDENT’,t=‘GOOD’,q=‘WORKER’。

求:

StrLength(s),StrLength(t),SubString(s,8,7),SubString(t,2,1),

Index(s,‘A’),Index(s,t),Replace(s,‘STUDENT’,q),

Concat(SubString(s,6,2),Concat(t,SubString(s,7,8)))

【10,5,1】(选自《数据结构题集》5.1,必做题)

假设有两维数组A6x8,每个元素用相邻的6个字节存储,存储按字节编址。

已知A的起始地址为1000,计算:

(1)数组A的存储量;

(2)数组A的最后一个元素a57的第一个字节的地址;

(3)按行存储时,元素a14的第一个字节的地址;

(4)按列存储时,元素a47的第一个字节的地址;

【11,6,1】(选自《数据结构题集》6.1,必做题)

已知一棵树边的集合为{},请画出这棵树,并回答下列问题:

(1)哪个是根结点?

(2)哪些是叶子结点?

(3)哪个是结点G的双亲?

(4)哪些是结点G的祖先?

(5)哪些是结点G的孩子?

(6)哪些是结点E的子孙?

(7)哪些是结点E的兄弟?

哪些是结点F的兄弟?

(8)结点B和N的层次号分别是什么?

(9)树的深度是多少?

(10)以结点C为根的子树的深度是多少?

【12,6,1】(选自《数据结构题集》6.4,选做题)

一棵深度为H的满k叉树有如下性质第H层上的结点都是叶子节点,其余各层上每个结点都有k棵非空子树。

如果按层次顺序从1开始对全部结点编号,问:

(1)各层的结点数目是多少?

(2)编号为p的父结点(若存在)的编号是多少?

(3)编号为p的结点的第i个儿子结点(若存在)的编号是多少?

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

当前位置:首页 > PPT模板 > 商务科技

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

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