大学计算机软件技术基础考试技术复习题Word下载.docx

上传人:b****4 文档编号:17082648 上传时间:2022-11-28 格式:DOCX 页数:13 大小:83.11KB
下载 相关 举报
大学计算机软件技术基础考试技术复习题Word下载.docx_第1页
第1页 / 共13页
大学计算机软件技术基础考试技术复习题Word下载.docx_第2页
第2页 / 共13页
大学计算机软件技术基础考试技术复习题Word下载.docx_第3页
第3页 / 共13页
大学计算机软件技术基础考试技术复习题Word下载.docx_第4页
第4页 / 共13页
大学计算机软件技术基础考试技术复习题Word下载.docx_第5页
第5页 / 共13页
点击查看更多>>
下载资源
资源描述

大学计算机软件技术基础考试技术复习题Word下载.docx

《大学计算机软件技术基础考试技术复习题Word下载.docx》由会员分享,可在线阅读,更多相关《大学计算机软件技术基础考试技术复习题Word下载.docx(13页珍藏版)》请在冰豆网上搜索。

大学计算机软件技术基础考试技术复习题Word下载.docx

e

(1)画出该图的图形;

〔2〕根据邻接矩阵从顶点a出发进展深度优先遍历和广度优先遍历,写出相应的遍历序列。

该图的图形为:

深度优先遍历序列为:

abdce

广度优先遍历序列为:

abedc

LListnote(LListT)//T是不带头结点的单链表的头指针

{

If(T&

&

T->

next){

p=T;

T=T->

next;

q=T;

Ro:

while(q->

next)q=q->

Rt:

q->

next=p;

}

returnT;

请答复以下问题:

〔1〕Ro和Rt行的功能是什么?

〔2〕说明算法的功能。

〔1〕Ro查询链表的尾结点,Rt将第一个结点到链表的尾部,作为新的尾结点

〔2〕使原单链表变为循环单链表,返回循环单链表的头指针

假设两个队列共享一个循环向量空间〔参见右以下图〕,

其类型Queue2定义如下:

typedefstruct{

DateTypedata[MaxSize];

intfront[2],rear[2];

}Queue2;

对于i=0或1,front[i]和rear[i]分别为第i个队列的头指针和尾指针。

请对以下算法填空,实现第i个队列的入队操作。

intEnQueue(Queue2*Q,inti,DateTypex)

{//假设第i个队列不满,那么元素x入队列,并返回1;

否那么返回0

if(i<

0||i>

1)return0;

if(Q->

rear[i]==Q->

front[①]return0;

Q->

data[②]=x;

Q->

rear[i]=[③];

return1;

}

①(i+1)%2(或1-i)

②Q->

rear[i]

③(Q->

rear[i]+1)%Maxsize

一个图如下所示,其顶点按a、b、c、d、e、f顺序存放在邻接表的顶点表中,请画出该图的邻接表,使得按此邻接表进展深度优先遍历时得到的顶点序列为acbefd,进展广度优先遍历时得到的顶点序列为acbdfe。

两个4×

5的稀疏矩阵的三元组表分别如下:

0141601132

12218122-22

234-2522569

3422833425

44251

请画出这两个稀疏矩阵之和的三元组表。

解:

从空树起,依次插入关键字40,8,90,15,62,95,12,23,56,32,构造一棵二叉排序树。

(1)画出该二叉排序树

(2)画出删去该树中元素值为90的结点之后的二叉排序树。

阅读以下函数algo,并答复以下问题。

(1)假设整型数组A[1..8]中的元素依次为(3,8,9,1,7,4,2,6)。

执行函数调用algo(A,8)时,外层while的循环体执行多少次?

函数的返回值是多少?

(2)简述函数algo(L,n)的功能。

intalgo(intL[],intn)

inti=0,j,s=1,t=n;

while(i!

=(n+1)/2)

intx=L[s];

i=s;

j=t;

while(i&

lt;

j)

j&

L[j]&

gt;

=x)j--;

L[i]=L[j];

L[i]&

=x)i++;

L[j]=L[i];

L[i]=x;

if(i&

(n+1)/2)s=i+1;

elset=i-1;

if(i==0)return0;

elsereturnL[i];

}

(1)

(2)(3)

33题答案:

〔1〕外循环执行4次,函数返回值为3。

〔2〕将A[1]至A[8]中不小于A[1]的元素进展递增排序,如调用algo(A,8)时最终排序结果为21346789

队和栈的主要区别是( 

A.逻辑构造不同 

B.存储构造不同

C.所包含的运算个数不同 

D.限定插入和删除的位置不同

链栈与顺序栈相比,比拟明显的优点是( 

A.插入操作更加方便 

B.删除操作更加方便

C.不会出现下溢的情况 

D.不会出现上溢的情况

二叉树中第5层上的结点个数最多为( 

A.8 

B.15

C.16 

D.32

假设队列q中的元素为(2,4,5,7,8),其中“2”为队头元素。

写出执行函数调用algo(&

q)后的队列q;

(2)简述算法algo的功能。

void 

algo(Queue 

*Q)

{

Stack 

S;

InitStack(&

S);

while 

(!

QueueEmpty(Q))

Push(&

S, 

DeQueue(Q));

StackEmpty(&

S))

EnQueue(Q,Pop(&

S));

}

(1)87542

(2) 

队列倒置

在数据构造中,数据的逻辑构造可以分成〔   〕

A.部构造和外部构造 

B.线性构造和非线性构造

C.紧凑构造和非紧揍构造 

D.动态构造和静态构造

在以单链表为存储构造的线性表中,数据元素之间的逻辑关系用〔   〕

A.数据元素的相邻地址表示 

B.数据元素在表中的序号表示

C.指向后继元素的指针表示 

D.数据元素的值表示

设p指向单链表中的一个结点,s指向待插入的结点,那么下述程序段的功能是〔   〕

     s 

->

next 

next;

s;

data;

data 

t;

A.结点*p与结点*s的数据域互换

B.在p所指结点的元素之前插入元素

C.在p所指结点的元素之后插入元素

D.在结点*p之前插入结点*s

栈和队列都是〔   〕

A.限制存取位置的线性构造 

B.顺序存储的线性构造

C.链式存储的线性构造 

D.限制存取位置的非线性构造

当在二叉排序树中插入一个新结点时,假设树中不存在与待插入结点的关键字一样的结点,且新结点的关键字小于根结点的关键字,那么新结点将成为〔   〕

A.左子树的叶子结点 

B.左子树的分支结点

C.右子树的叶子结点 

D.右子树的分支结点

希尔排序的增量序列必须是〔   〕

A.递增的 

B.随机的

C.递减的 

D.非递减的

如果在排序过程中,每次均将一个待排序的记录按关键字大小参加到前面已经有序的子表中的适当位置,那么该排序方法称为〔   〕

A.插入排序 

B.归并排序

C.冒泡排序 

D.堆排序

指针p指向单链表中某个结点,那么语句p 

=p 

next的作用是________________。

删除*P的直接后继结点

删除双向循环链表中*p的前驱结点(存在)应执行的语句是____________。

p->

pre;

q->

pre->

p;

pre 

free( 

);

栈下溢是指在____栈空________时进展出栈操作。

完全二叉树T的第5层只有7个结点,那么该树共有___2^3 

11___个叶子结点。

在有向图中,以顶点v为终点的边的数目称为v的_____入度_______。

假设元素只能按a,b,c,d的顺序依次进栈,且得到的出栈序列中的第一个元素为c,那么可能得到的出栈序列为________________,不可能得到的出栈序列为________________

1)cbad, 

cbda, 

cdba

2)cabd, 

cadb, 

cdab

假设以邻接矩阵表示有向图,那么邻接矩阵上

 第i行中非零元素的个数即为顶点vi的________________。

出度

以下函数的功能是,对以带头结点的单链表作为存储构造的两个递增有序表〔表中不存在值一样的数据元素〕进展如下操作:

将所有在Lb表中存在而La表中不存在的结点插入到La中,其中La和Lb分别为两个链表的头指针。

请在空缺处填入适宜容,使其成为一个完整的算法。

 void 

union 

(LinkList 

La, 

LinkList 

Lb)

//本算法的功能是将所有Lb表中存在而La表中不存在的结点插入到La表中

q;

pa 

La 

pb 

Lb 

free 

(Lb);

(pa 

pd)

if 

<

data)

pa;

else 

>

(1) 

;

pb;

else

(q);

(pb)

(3) 

pb

pa

整形数组L[1..8]中的元素依次为〔9,8,5,7,6,3,2,1〕,阅读以下函数,并写出执行函数调用 sort(L, 

8)时,对L进展的头两趟〔pass分别为0和1〕处理结果。

 Void 

sort 

(int 

R[],int 

n)

  

int 

pass 

0, 

k, 

exchange, 

x;

do 

k=pass%2+1;

exchange 

0;

(k<

 if 

(R[k]>

R[k+1])

 {

R[k];

R[k] 

R[k+1];

R[k+1] 

=1;

K+=2

 pass 

++;

}while 

(exchange 

1|| 

=1);

第一趟〔pass 

0〕:

第二趟〔pass 

1〕:

在长度为n的顺序表中删除第i个元素(1≤i≤n)时,元素移动的次数为( 

A. 

n-i+1 

B. 

i

C. 

i+1 

D. 

n-i

假设不带头结点的单链表的头指针为head,那么该链表为空的判定条件是( 

head==NULL 

head->

next==NULL

head!

=NULL 

next==head

引起循环队列队头位置发生变化的操作是( 

出队 

入队

取队头元素 

取队尾元素

假设进栈序列为1,2,3,4,5,6,且进栈和出栈可以穿插进展,那么不可能出现的出栈序列是( 

2,4,3,1,5,6 

3,2,4,1,6,5

4,3,2,1,5,6 

2,3,5,1,6,4对关键字序列(56,23,78,92,88,67,19,34)进展增量为3的一趟希尔排序的结果为( 

(19,23,56,34,78,67,88,92) 

(23,56,78,66,88,92,19,34)

(19,23,34,56,67,78,88,92) 

(19,23,67,56,34,78,92,88)

由同一关键字集合构造的各棵二叉排序树( 

其形态不一定一样,但平均查找长度一样

其形态不一定一样,平均查找长度也不一定一样

其形态均一样,但平均查找长度不一定一样

其形态均一样,平均查找长度也都一样

数据的逻辑构造在计算机存储器的表示,称为数据的_____存储构造_______。

假设以数组seqn[m]存放循环队列的元素,设变量rear和quelen分别指示循环队列中队尾元素的位置和元素的个数。

(1)写出队满的条件表达式;

(2)写出队空的条件表达式;

(3)设m=40,rear=13,quelen=19,求队头元素的位置;

(4)写出一般情况下队头元素位置的表达式。

quelen 

== 

m

( 

13 

19 

40 

) 

34

(4) 

rear 

阅读以下算法,并答复以下问题:

(1)设顺序表L=(3,7,11,14,20,51),写出执行f30(&

L,15)之后的L;

(2)设顺序表L=(4,7,10,14,20,51),写出执行f30(&

L,10)之后的L;

(3)简述算法的功能。

f30(SeqList*L, 

DataType 

x)

=0, 

j;

(i<

L->

length 

x>

data[i])i++;

x==L->

data[i]) 

{//找到x,那么删除x,大于x的数前移

for(j=i+1;

j<

length;

j++)

data[j-1]=L->

data[j];

length--;

{//没找到,插入x, 

大于x的数后移

for(j=L->

j>

i;

j--)

data[j]=L->

data[j-1];

data[i]=x;

length++;

L=(3,7,11,14,15,20,51)

L=(4,7,14,20,51)

在顺序表L中查找数x,

找到,那么删除x,

没找到,那么在适当的位置插入x,插入后,L依然有序.

假设数组L[8]={3,0,5,1,6,4,2,7},写出执行函数调用f32(L,8)后的L;

(2)写出上述函数调用过程中进展元素交换操作的总次数。

f32(int 

R[],int 

n){

i,t;

for 

(i=0;

i<

n-1;

i++)

(R[i]!

=i){

t=R[R[i]];

R[R[i]]=R[i];

R[i]=t;

while(){}里是把R[ 

和 

R[ 

交换;

1, 

2, 

3, 

4, 

5, 

6, 

};

(2)5次能进展二分查找的线性表,必须以〔 A  〕

A.顺序方式存储,且元素按关键字有序

B.链式方式存储,且元素按关键字有序

C.顺序方式存储,且元素按关键字分块有序

D.链式方式存储,且元素按关键字分块有序

数组采用顺序存储方式表示是因为通常不对数组进展___插入和删除______操作。

结点数为20的二叉树可能达期的最大高度为____19_____。

在现代操作系统中引入了〔〕,从而使并发和共享成为可能。

A.单道程序B.磁盘C.对象D.多道程序

()操作系统允许在一台主机上同时连接多台终端,多个用户可以通过各自的终端同时交互地使用计算机。

A.网络B.分布式C.分时D.实时

当一个进程处于〔〕状态时,称其为等待〔或阻塞〕状态。

A.它正等待中央处理机B.它正等待合作进程的一个消息

C.它正等待分给它一个时间片D.它正等待进入存

一个进程释放一种资源将有可能导致一个或几个进程〔〕。

A.由就绪变运行B.由运行变就绪C.由阻塞变运行D.由阻塞变就绪

有m个进程共享同一临界资源,假设使用信号量机制实现对一临界资源的互斥访问,那么信号量的变化围是〔〕。

A.1至–(m-1)B.1至m-1C.1至–mD.1至m

在下面关于虚拟存储器的表达中,正确的选项是〔〕。

A.要求程序运行前必须全部装入存且在运行过程中一直驻留在存

B.要求程序运行前不必全部装入存且在运行过程中不必一直驻留在存

C.要求程序运行前不必全部装入存但是在运行过程中必须一直驻留在存

D.要求程序运行前必须全部装入存但在运行过程中不必一直驻留在存

采用段式存储管理的系统中,假设地址用24位表示,其中8位表示段号,那么允许每段的最大长度是〔〕。

A.224B.216C.28D.232

进程主要由__程序_____、___数据_____和_____PCB_______三局部容组成,其中____PCB____是进程存在的惟一标识,而_____数据_____局部也可以为其它进程共享。

当处理器空闲时,调度程序从__就绪_____进程队列中选择一个进程给其分配CPU,处于____阻塞________状态的进程是不会获得CPU的。

在响应比最高者优先的作业调度算法中,当各个作业等待时间一样时,运行时间短_____的作业将得到优先调度;

当各个作业要求运行的时间一样时,___等待时间长___的作业得到优先调度。

某系统中共有10台磁带机被m个进程竞争,每个进程最多要求3台磁带机,那么当m的取值为_不超过4的整数___时,系统不会发生死锁。

设有8页的逻辑空间,每页有1024字节,它们被映射32块的物理存储区中,那么,逻辑地址的有效位是__13________位,物理地址至少是_____15_____位。

在一个分页存储管理系统中,页长为4KB,

页号

物理块号

1

4

6

某一作业的页表如图1所示,虚拟地址3000对应的物理地址为12K+3000=152888。

说明作业调度和进程调度的区别,分析:

在可获得处理机时,应将它分给哪个就绪进程

由哪一级调度程序负责?

答:

作业调度用于决定把外存中处于后备队列中的哪些作业调入存,并为它们创立进程,分配资源,然后将新创立进程插入就绪队列;

进程调度决定将处理机分配给就绪进程队列的哪个进程。

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

当前位置:首页 > 职业教育 > 其它

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

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