堆栈模拟队列(python)
2021/9/25 17:42:16
本文主要是介绍堆栈模拟队列(python),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
设已知有两个堆栈S1和S2,请用这两个堆栈模拟出一个队列Q。
所谓用堆栈模拟队列,实际上就是通过调用堆栈的下列操作函数:
int IsFull(Stack S):判断堆栈S是否已满,返回1或0;
int IsEmpty (Stack S ):判断堆栈S是否为空,返回1或0;
void Push(Stack S, ElementType item ):将元素item压入堆栈S;
ElementType Pop(Stack S ):删除并返回S的栈顶元素。
实现队列的操作,即入队void AddQ(ElementType item)和出队ElementType DeleteQ()。
输入格式:
输入首先给出两个正整数N1和N2,表示堆栈S1和S2的最大容量。随后给出一系列的队列操作:A item表示将item入列(这里假设item为整型数字);D表示出队操作;T表示输入结束。
输出格式:
对输入中的每个D操作,输出相应出队的数字,或者错误信息ERROR:Empty。如果入队操作无法执行,也需要输出ERROR:Full。每个输出占1行。
输入样例:
3 2
A 1 A 2 A 3 A 4 A 5 D A 6 D A 7 D A 8 D D D D T
结尾无空行
输出样例:
ERROR:Full
1
ERROR:Full
2
3
4
7
8
ERROR:Empty
结尾无空行
首先这题需要搞懂题目的意思
两个栈,一个大的一个小的,就以2和3为例
我们先往小的栈里面添加元素直到栈满,然后把小栈内的元素都放入大栈中,这个时候如果小栈又满了,就不能往大栈中继续放了,因为队列只能一头进一头出,这个时候就输出满,这就解释了为什么例题中加了四个就满了。删除的话删除大栈里面的元素,当删光了之后,把小栈里面的元素加到大栈中,如果大栈和小栈都没元素,再删就输出空。
代码如下:
m,n=input().split() m=min(int(m),int(n)) lst=input().split() lst1,lst2=[],[] for i in range(len(lst)-1): if lst[i]=='A': if len(lst1)==m and lst2==[]: lst1.reverse() lst2=lst1[:] lst1.clear() lst1.append(lst[i+1]) elif len(lst1)==m and lst2!=[]: print('ERROR:Full') elif len(lst1)!=m: lst1.append(lst[i+1]) elif lst[i].isdigit(): continue else: if lst2!=[]: print(lst2.pop()) elif lst2==[] and lst1!=[]: lst1.reverse() lst2=lst1[:] lst1.clear() print(lst2.pop()) elif lst1==[] and lst2==[]: print('ERROR:Empty')
这篇关于堆栈模拟队列(python)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-26Python基础编程
- 2024-11-25Python编程基础:变量与类型
- 2024-11-25Python编程基础与实践
- 2024-11-24Python编程基础详解
- 2024-11-21Python编程基础教程
- 2024-11-20Python编程基础与实践
- 2024-11-20Python编程基础与高级应用
- 2024-11-19Python 基础编程教程
- 2024-11-19Python基础入门教程
- 2024-11-17在FastAPI项目中添加一个生产级别的数据库——本地环境搭建指南