第3课-栈、队列和数组

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

第三课栈、队列和数组

一选择题

1.对于栈操作数据的原则是()。

A.先进先出B.后进先出C.后进后出D.不分顺序

2.一个栈的输入序列为123…n,若输出序列的第一个元素是n,输出第i(1<=i<=n)个元素是()。

A.不确定B.n-i+1 C.i D.n-i

3.若一个栈的输入序列为1,2,3,…,n,输出序列的第一个元素是i,则第j个输出元素是()。

A.i-j-1 B.i-j C.j-i+1 D.不确定的

4.设abcdef以所给的次序进栈,若在进栈操作时,允许出栈操作,则下面得不到的出栈序列为()。

A.fedcba B.bcafed C.dcefba D.cabdef

5.输入序列为ABC,可以变为CBA时,经过的栈操作为()

A.push,pop,push,pop,push,pop B.push,push,push,pop,pop,pop

C.push,push,pop,pop,push,pop D.push,pop,push,push,pop,pop

6.若一个栈以向量V[1..n]存储,初始栈顶指针top为n+1,则下面x进栈的正确操作是()。

A.top=top+1; V[top]=x B.V[top]=x; top=top+1

C.top=top-1; V[top]=x D.V[top]=x; top=top-1

7.若栈采用顺序存储方式存储,现两栈共享空间V[1..m],top[i]代表第i个栈(i =1,2)栈顶,栈1的底在v[1],栈2的底在V[m],则栈满的条件是()。

A.|top[2]-top[1]|==0 B.top[1]+1==top[2] C.top[1]+top[2]==m D.top[1]==top[2]

8.执行完下列语句段后,i值为:()。

int f(int x)

{ return ((x>0) ? x* f(x-1):2);}

int i;

i =f(f(1));

A.2 B.4 C.8 D.无限递归

9.表达式a*(b+c)-d的后缀表达式是()。

A.abcd*+- B.abc+*d- C.abc*+d- D.-+*abcd

10.表达式3*2^(4+2*2-6*3)-5求值过程中当扫描到6时,对象栈和算符栈为(),其中^为乘幂。

A.3,2,4,1,1;(*^(+*- B.3,2,8;(*^- C.3,2,4,2,2;(*^(- D.3,2,8;(*^(-

11.用不带头结点的单链表存储队列时,其队头指针指向队头结点,其队尾指针指向队尾结点,则在进行删除操作时()。

A.仅修改队头指针B.仅修改队尾指针

C.队头、队尾指针都要修改D.队头、队尾指针都可能要修改

12.递归过程或函数调用时,处理参数及返回地址,要用一种称为()的数据结构。

A.队列B.多维数组C.栈D.线性表

13.循环队列A[0..m-1]存放其元素值,用front和rear分别表示队头和队尾,则当前队列中的元素数是()。

A.(rear-front+m)%m B.rear-front+1 C.rear-front-1 D.rear-front

14.循环队列存储在数组A[0..m]中,则入队时的操作为()。

A.rear=rear+1 B.rear=(rear+1) mod (m-1)

C.rear=(rear+1) mod m D.rear=(rear+1) mod (m+1)

15.若用一个大小为6的数组来实现循环队列,且当前rear和front的值分别为0和3,当从队列中删除一个元素,再加入两个元素后,rear和front的值分别为多少?()A.1和5 B.2和4 C.4和2 D.5和1

16.最大容量为n的循环队列,队尾指针是rear,队头是front,则队空的条件是()。

A.(rear+1) MOD n==front B.rear==front

C.rear+1==front D.(rear-l) MOD n==front

17.设栈S和队列Q的初始状态为空,元素e1,e2,e3,e4,e5和e6依次通过栈S,一个元素出栈后即进队列Q,若6个元素出队的序列是e2,e4,e3,e6,e5,e1则栈S的容量至少应该是()。

A.6 B.4 C.3 D.2

18.数组A[0..4,-1..-3,5..7]中含有元素的个数()。

A.55 B.45 C.36 D.16

19.设二维数组A[1..m,1..n](即m行n列)按行存储在数组B[1..m*n]中,则二维数组元素A[i,j]在一维数组B中的下标为()。

A.(i-1)*n+j B.(i-1)*n+j-1 C.i*(j-1) D.j*m+i-1

20.设有一个10阶的对称矩阵A,采用压缩存储方式,以行序为主存储,a11为第一元素,其存储地址为1,每个元素占一个地址空间,则a85的地址为()。

A.13 B.33 C.18 D.40

21.设有数组A[i,j],数组的每个元素长度为3字节,i的值为1 到8 ,j的值为1 到10,数组从内存首地址BA开始顺序存放,当用以列为主存放时,元素A[5,8]的存储首地址为()。

A.BA+141 B.BA+180 C.BA+222 D.BA+225

22.数组A[0..5,0..6]的每个元素占五个字节,将其按列优先次序存储在起始地址为1000的内存单元中,则元素A[5,5]的地址是( )。

A .1175

B .1180

C .1205

D .1210

23.将一个A[1..100,1..100]的三对角矩阵,按行优先存入一维数组B[1‥298]中,A 中元素A 66,65(即该元素下标i=66,j=65),在B 数组中的位置K 为( )。

A .198

B .195

C .197

D .196

24.对稀疏矩阵进行压缩存储目的是( )。

A .便于进行矩阵运算

B .便于输入和输出

C .节省存储空间

D .降低运算的时间复杂度

25.有一个100*90的稀疏矩阵,非0元素有10个,设每个整型数占2字节,则用三元组表示该矩阵时,所需的字节数是( )。

A .60

B .66

C .18000

D .33

二、应用题

1.有5个元素,其入栈次序为A 、B 、C 、D 、E ,在各种可能的出栈次序中,以元素C ,D 最先出栈(即C 第一个且D 第二个出栈)的次序有哪几个?

2.如果输入序列为1 2 3 4 5 6,试问能否通过栈结构得到以下两个序列:4 3 5 6 1 2和1 3 5 4 2 6,请说明为什么不能或如何才能得到。

3.试证明:若借助栈由输入序列1,2,…,n 得到输出序列为P 1,P 2,…,P n (它是输入序列的一个排列),则在输出序列中不可能出现这样的情形:存在着i

参考答案:

如果ip j 的情况,则说明要将p j 压到p i 之上,也就是在p j 出栈之后p i 才能出栈。这就说明,对于i

4.用栈实现将中缀表达式8-(3+5)*(5-6/2)转换成后缀表达式,画出栈的变化过程图。 参考答案:

中缀表达式8-(3+5)*(5-6/2)的后缀表达式是: 8 3 5 + 5 6 2 / - * -

表达式生成过程为:

中缀表达式exp1转为后缀表达式exp2的规则如下:

设操作符栈s ,初始为空栈后,压入优先级最低的操作符‘#’。对中缀表达式从左向右

(2)8 3 5 + 5 6 2#*# (3

)8 3 5 + 5 6 2 / -(4)8 3 5 + 5 6 2 / - * --#*(/)--) (1)8 3 5#(+-

相关文档
最新文档