-
用单链表表示的链式队列的队头和队尾分别在链表的( )位置
A.链头和链尾
B.链尾和链头
C.链头和链中
D.链尾和链中 -
堆栈和队列的主要区别是( )
A.限定元素插入和删除的位置不同
B.逻辑结构不同
C.存储结构不同
D.名字不同 -
栈和队列的共同点是( )
A.都是先进先出
B.都是线性结构
C.具有相同存储结构
D.没有共同点栈和队列具有相同的逻辑结构,都可以用顺序存储或链表存储,都是一种受限的线性表。
-
一个递归算法必须包括( )
A.递归部分
B.终止条件和递归部分
C.迭代部分
D.终止条件和迭代部分 -
递归过程或函数调用时,处理参数及返回地址,要用一种称为___的数据结构。
A.队列
B.数组
C.线性表
D.堆栈 -
最多可存储n个数据元素的循环队列,front为队头标识,rear为队尾标识,则队满的条件是()
A. (rear+1)%n== front
B.(front+1)%n==rear
C. (rear+1)%(n+1)==front
D. (front+1)%(n+1)==rear -
设数组data[20]作为循坏队列SQ的存储空间, front指向队头,则data[front+1]为队头元素。×
循环队列的队头元素不会发生改变。
-
设数组data[100]作为循环队列sQ的存储空间,front为队头标识,rear为队尾标识,当front== 80,rear==15时,以下说法正确的是__。
A.队列元素个数为34
B. data数组中下标从16到79的位置都为空闲位置
C. data数组中下标从16到80的位置都为空闲位置
D.队列元素个数为36解析:
空闲位置不包括front。 -
a^2的后缀表达式是aa*。X a2^
-
两个堆栈 S1、S2,实现队列的入队、出队、判断队空的操作。
创建两个栈,s1 和 s2,s1 负责入栈,s2 负责出栈;
队列入队:入队时,直接将元素入 s1 栈即可。
队列出队:出队时需要 s2 出栈,因此要判定 s2 是否为空;若 s2 为空,则将 s1中元素一一出栈进入 s2 栈中,此时 s2 已不为空;那么队列出队只需将 s2 出栈即可。 当然,如果 s1 和 s2 均为空,则出队失败。
判断队空:判断 s1 栈是否为空。 -
为什么队列的顺序表示会出现“假溢出”现象,通常如何解决这一问题。
在顺序队列中,由于频繁的入队和出队操作造成队列有剩余空间却无法完成入队的现象,即为“假溢出”现象。
解决方法:可采用循环队列来解决,通过求余运算将队列从逻辑上构成一个环状结构。 -
说明有几种度量程序执行时间的方法,并说明优缺点。
事后计算。
事前分析估算。
811 第三章 堆栈和队列考点
于 2023-11-27 10:38:45 首次发布