数据结构 栈、队列复习

一、栈

栈的插入和删除都是在栈顶进行的


二、链栈  (无头结点的单链表,插入和删除都在头结点的链表头上


1、


2、

链栈是无头结点的单链表,插入和删除都在最头上进行


3、

答案:F

解析:应该是不确定,因为,一串数据依次通过一个栈,并不能保证出栈数据的次序总是倒置,可以产生多种出栈序列。一串数据通过一个栈后的次序由每个数据之间的进栈、出栈操作序列决定,只有当所有数据“全部进栈后再全部出栈”才能使数据倒置。事实上,存在一种操作序列——“进栈、出栈、进栈、出栈……”——可以使数据通过栈后仍然保持次序不变。
题目中输出序列的第一个元素是i,则第j个输出元素是不确定的。


4、


5、


6、


7、

这个题,*入栈,+的优先级低,所以*出栈,+再入栈,/的优先级高,所以/入栈,之后/和+依次出栈

所以为入、出、入、入、出、出,答案为C

 

将中缀表达式转换为后缀表达式,相应的堆栈操作序列:


 

栈内=栈外:出栈 栈内的操作符并入栈 栈外的操作,

 

  • 如果栈为空,或栈顶运算符为左括号“(”,则直接将此运算符入栈;
  •  栈内<栈外:栈外操作符入栈
  •  栈内>栈外:栈内符合条件的操作符出栈之后,栈外操作符再入栈(同级后来的视为低优先级,也就是,比如已经有*,后来了一个/,那么/的优先级低于*,先应执行*出栈,然后/再入栈)
  • 遇到 ‘(’:直接入栈,“(”视为最低优先级的符号
  • 遇到 ‘)’:出栈所有操作符直达遇到 ‘(’
  • 符号和字母在两个栈中,出栈的符号都进入字母所在的栈中了

8、

  • +1入
  • *入(因为*优先级高于+)、出(因为+优先级小于*)
  • +1出(因为+同级,后来的视为低优先级)、+2入
  • “(”入
  • *入(因为“(”为最低优先级)、出(因为+优先级小于*)
  • +入

此时为+(+


9、

解析:

a(入)*(入)、“(”(入)、b(入)+(入)、c(入)+(出)*(出)-(入)、d(入)、-(出)

做题的时候,一个字母栈,一个字符栈,遇到字母就进入字母栈,字符是只有出栈的才能到字母栈中


一、链对列(有头结点、头指针和尾指针的单链表)

  • 队尾进入队头出
  • 含有头结点

二、循环队列

  • 插入了n个元素:Q.rear=(Q.rear+n)%MAXQSIZE;
  • 删除了n个元素:Q.front=(Q.front+n)%MAXQSIZE;
  • 循环对列长度:(Q.rear-Q.front+MAXQSIZE)%MAXQSIZE;

1、


2、

 


3、


4、


5、


6、


7、

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值