- 23
- 0
- 约5.34千字
- 约 33页
- 2017-11-24 发布于河南
- 举报
栈与队列(习题课)
第三章习题 填空题 1.线性表、栈和队列从逻辑上来说都是____________结构。可以在线性表的_______位置插入和删除元素;对于栈只能在__________插入和删除元素;对于队列只能在___________插入元素和在_________删除元素。 线性,任何,栈顶,队尾,队头 2.栈的插入和删除只能在栈的栈顶进行,后进栈的元素必定先出栈,所以又把栈称为__________表;队列的插入和删除运算分别在队列的两端进行,进行插入的一端叫做__________,进行删除的一端叫做___________,先进队的元素必定先出队,所以又把队列称为____________表。 先进后出(FILO),队尾,队头,先进先出(FIFO) 3.假设用向量S[1:m]来存储顺序栈,指针top指向当前栈顶的位置。则当栈为空时满足的条件是____________;当栈为满时满足的条件是_____________。 top==0,top==m 4.设有一个空栈,现有输入序列1、2、3、4、5,经过push、push、pop、push、pop、push、push、pop、pop、 pop后,输出序列为__________________。 23541 5.在一个顺序循环队列中为了方便入队列和出队列的操作通常约定头指针front指向实际队头元素的____________,尾指针rear指向当前实际队尾元素的____________。若该顺序循环队列有m个存储单元,则队列满时共有__________个元素。 前一个位置,所在位置,m-1 分析:在顺序循环队列中约定头指针front和尾指针rear所指向的位置,是牺牲掉一个存储单元而方便表示队列空和队列满的条件,因此顺序循环队列中实际可用的存储单元只有m-1个 6.设有一个顺序循环队列如上题中的约定,则该队列满的条件是_________,队列空的条件是_________。 (rear+1)%m==front,rear==front 7.不论是顺序栈(队列)还是链式栈(队列),插入(删除)运算的时间复杂度均为________。 O(1) 8.系统在函数调用前自动把调用后的____________压入堆栈;当函数调用结束后,系统又自动作退栈处理,并将程序执行流程无条件转移到所保存的_____________处继续执行。 返回地址,返回地址 选择题 1.设栈的输入序列是1、2、3、…、n,输出序列的第一个元素是n,则第i个输出元素是( )。 ① n-i ② n-i-1 ③ n-i+1 ④不确定 (3) 分析:设栈的输入序列是1、2、3、……、n,输出序列的第一个元素是n,则输出序列必定是n、n-1、n-2、……、1,因此第i个输出元素是n+1-i。 2.设元素进栈次序为A、B、C、D、E,则下列不可能的出栈序列是( )。 ① ABCDE ② BCDEA ③ EABCD ④ EDCBA (3) 3.设用一维数组s[m]表示栈的存储空间,用top指向当前栈顶元素(其初始值为-1),则进行出栈时的操作序列是( )。 ① x=s[op]; ② x=s[top];top=0; ③ x=s[top];top==top-1; ④ x=s[top];top==top+1; (3) 4.设指针hs指向栈顶,指针s指向插入的结点A,则插入结点A时的操作为( )。 ① hs-next=s;② s-next=hs; hs=s; ③ s-next=hs-next; hs-next=s;④ s-next=hs; hs=hs-next; (2) 5.设用一维数组s[m]表示栈的存储空间,用top指向当前栈顶元素(其初始值为-1),则进行入栈时的操作序列是( )。 ① s[top] =x; ② top=top+1;s[top]=x; ③ top==top-1;s[top]=x; ④ s[top]=x;top==top+1; (2) 6.设front是链式队列的头指针,rear是链式队列的尾指针,s指向插入的结点A,则插入结点A的操作为( )。 ① front-next=s; front=s; ② s-next=rear; rear=s; ③ rear-next=s; rear=s; ④ s-next=front; front=s; (3) 7.设front是链式队列的头指针,rear是链式队列的尾指针,则删除队头元素的操作为( )。 ① front=front-next; ② rear=rear-next ; ③ rear=front-next ; ④ front=rear-next; (1) 8.对于一个具有m个存储单元的顺序循环队列,设front为队头指针,rear为队尾指针,则该
原创力文档

文档评论(0)