Python可以实现栈的结构吗
栈(stack)又名堆栈,它是一种运算受限的线性表。在Python中可使用列表进行实现。
什么是栈?
栈(stack)又名堆栈,它是一种运算受限的线性表。其限制是仅允许在表的一端进行插入和删除运算。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。
如何实现?
在Python中使用列表来实现:
#!/usr/bin/env python #定义一个列表来模拟栈 stack = [] #进栈,调用列表的append()函数加到列表的末尾,strip()没有参数是去掉首尾的空格 def pushit(): stack.append(raw_input('Enter new string: ').strip()) #出栈,用到了pop()函数 def popit(): if len(stack) == 0: print 'Cannot pop from an empty stack!' else: print 'Removed [', stack.pop(), ']' #编历栈 def viewstack(): print stack #CMDs是字典的使用 CMDs = {'u': pushit, 'o': popit, 'v': viewstack} #pr为提示字符 def showmenu(): pr = """ p(U)sh p(O)p (V)iew (Q)uit Enter choice: """ while True: while True: try: #先用strip()去掉空格,再把第一个字符转换成小写的 choice = raw_input(pr).strip()[0].lower() except (EOFError, KeyboardInterrupt, IndexError): choice = 'q' print '\nYou picked: [%s]' % choice if choice not in 'uovq': print 'Invalid option, try again' else: break #CMDs[]根据输入的choice从字典中对应相应的value,比如说输入u,从字典中得到value为pushit,执行pushit()进栈操作 if choice == 'q': break CMDs[choice]() #判断是否是从本文件进入,而不是被调用 if __name__ == '__main__': showmenu()
实例内容扩展:
# -*- coding:utf-8 -*- # __author__ :kusy # __content__:文件说明 # __date__:2018/9/30 17:28 class MyStack(object): def __init__(self): self.stack_list = [] self.count = 0 # 创建一个栈 def create_stack(self): return self.stack_list # 栈中添加值 def push(self, value): self.stack_list.insert(0,value) self.count += 1 #返回栈顶元素值 def peek(self): if self.count: return self.stack_list[0] # 删除栈顶元素 def pop(self): self.stack_list.pop(0) self.count -= 1 # 返回栈是否为空 def is_empty(self): return self.count == 0 #打印栈内容 def print_all(self): for sl in self.stack_list: print(sl) if __name__ == '__main__': ms = MyStack() ms.create_stack() ms.push(1) ms.push(2) ms.push(3) print('栈元素:') ms.print_all() print('栈顶元素:',ms.peek()) ms.pop() print('栈顶元素删除后:') ms.print_all() print('栈是否为空:','是' if ms.is_empty() else '否') print('---继续删除元素') ms.pop() print('---继续删除元素') ms.pop() print('栈是否为空:','是' if ms.is_empty() else '否')
运行结果如下
C:\Users\suneee\AppData\Local\Programs\Python\Python36\python.exe E:/wangjz/PyWorkSpace/LearnPython/PY0929/stack.py 栈元素: 3 2 1 栈顶元素: 3 栈顶元素删除后: 2 1 栈是否为空: 否 ---继续删除元素 ---继续删除元素 栈是否为空: 是 Process finished with exit code 0
到此这篇关于Python可以实现栈的结构吗的文章就介绍到这了,更多相关Python实现栈的结构的条件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Python图像处理库PIL的ImageEnhance模块使用介绍
这篇文章主要介绍了Python图像处理库PIL的ImageEnhance模块使用介绍,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-02-02正则给header的冒号两边参数添加单引号(Python请求用)
这篇文章主要介绍了正则给header的冒号两边参数添加单引号(Python请求用)的相关知识,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下2019-08-08
最新评论