3.1-栈

China☆狼群 提交于 2019-12-15 23:58:23

一、单选

1. 栈和队列具有相同的( )。

A. 抽象数据类型
B. 逻辑结构
C. 存储结构
D. 运算
[Solution]
栈和队列具有相同的逻辑结构,即线性逻辑结构,
$therefore B$✔️.

8. 向一个栈顶指针为top的链栈中插入一个x结点,则执行( )。

A. top->next=top;
B. x->next=top->next;top->next=x;
C. x->next=top;top=x;
D. x->next=top;top=top->next;
[Solution]
链栈采用不带头结点的单链表表示时,进栈操作在首部插入一个结点x(x->next=top;),再将top指向该插入的结点(top=x;)
Push时,先让top与新结点联系上,再进行插入。如顺序栈的Push:top先+1,后插入;链栈的Push:x->next = top; top = x;
$therefore B$✔️.

9. 链栈执行Pop操作,并将出栈的元素存在x中应该执行( )。

A. x=top;top=top->next
B. x=top->data;
C. top=top->next;x=top->data;
D. x=top->data;top=top->next;
[Analysis]
出栈时,应该元素先出栈,top再-1。即x=top->data;top=top->next;
$therefore D$✔️.

11. 3个不同元素进栈,能得到( )种不同的出栈序列。

A. 4
B. 5
C. 6
D. 7
[Analysis]
出栈序列的个数=卡特兰(Catalan)数=

组合数=

$therefore B$✔️.

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

A. i-j+1
B. i-j
C. j-i+1
D. 不确定
[Analysis]
j都不知道是个啥,咋子确定嘛。
$therefore D$✔️.

23.[2013] 一个栈的入栈序列为1,2,3,…,n,其出栈序列为$p_1$,$p_2$,$p_3$,…,$p_n$。若$p_2=3$,则$p_3$可能取指的个数是( )。

A. n-3
B. n-2
C. n-1
D. 无法确定
[Analysis]
(1) $p_3$为3之后的数,即4,5,…,n都是可能取的数;
(2) $p_3$为3之前的数,即1或2:当$p_3$为2时,$p_1$为1,很合理;当$p_3$为1时,$p_1$就应该为2(2先出去了)。
故$p_3$可去除了3以外的所有数,即n-1个。
$therefore C$✔️.

24. 设栈的初始状态为空,当字符序列“n 1 _”作为栈的输入时,输出长度为3,且可用作C语言标识符的序列有( )个。

A. 4
B. 5
C. 3
D. 6
[Analysis]
n 1不能出现。可以出现的序列有:_n1,_1n,n1
$therefore C$✔️.

二、综合应用题

4. 设单链表的表头指针为L,结点结构由data和next两个域构成,其中data域为字符型。试着设计算法判断该链表的全部n个字符是否中心对称,例如xyx,xyyx,都是中心对称。

12345678910111213
int (LinkList L, int n){    char stack[n/2];                    int index;                      // 字符栈的工作指针    LNode *p = L->next;             // 单链表的工作指针    if(L->next == NULL) return 0;    for(index = 0; index < n/2; index++, p = p->next)   // 单链表中的前一半元素入栈      大专栏  3.1-栈   stack[index] = p->data;    index--;                        // index == n/2-1,即字符栈中的最后一个元素    if(n % 2 == 1) p = p->next;     // 当n为奇数时,跳过中心结点    for( ;stack[index] == p->data && p->next != NULL; index--, p = p->next);    if(index == -1) return 1;       // 栈为空栈,则单链表中心对称    else return 0;}

5. 设有两个栈s1和s2都采用顺序栈方式,并且共享一个存储区[0…maxsize-1]。为了尽量利用空间,减少溢出的可能,可采用栈顶相向、迎面增长的存储方式。试着设计s1和s2有关入栈和出栈的操作算法。

1234567891011121314151617181920212223242526272829303132333435363738394041
#define ElemType inttypedef struct{    ElemType data[MaxSize];  // 栈空间    int top[2];              // top为两个栈顶指针,top[0]为左边的栈s1,top[1]为右边的栈s2} Stack;Stack stack;                // 将stack声明为全局变量int Push(int whichOne, ElemType value){    if(whichOne < 0 || whichOne > 1) retrun 0;    if(top[1] - top[0] == 1){        printf("栈已满");        return 0;    }    if(whichOne == 0)        stack[++top[0]] = value;    else if(whichOne == 1)        stack[--top[1]] = value;    return 0;}ElemType Pop(int whichOne){    if(whichOne < 0 || whichOne > 1) retrun 0;    if(wichiOne == 0){        if(top[0] == -1){            printf("栈为空");            return -1;        }        else            return stack[top[0]--];    }    else if(whichOne == 1){        if(top[1] == MaxSize){            printf("栈为空");            return -1;        }        else            return stack[top[1]++];    }}
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!