Python堆栈(Stack)

Python堆栈(Stack) 首页 / 数据结构入门教程 / Python堆栈(Stack)

Stack 堆栈存储数据元素 就像一堆盘子在厨房里一个个又一个地存放一样,允许在一端的操作可称为堆栈顶部, 无涯教程只能在堆栈中添加或删除元素。

压入堆栈

class Stack:

    def __init__(self):
        self.stack=[]

    def add(self, dataval):
# 使用列表追加方法添加元素
        if dataval not in self.stack:
            self.stack.append(dataval)
            return True
        else:
            return False
# 使用 peek 查看栈顶

    def peek(self):     
	    return self.stack[-1]

AStack=Stack()
AStack.add("Mon")
AStack.add("Tue")
AStack.peek()
print(AStack.peek())
AStack.add("Wed")
AStack.add("Thu")
print(AStack.peek())

执行以上代码后,将产生以下输出:

无涯教程网

Tue
Thu

删除数据

众所周知,无涯教程只能从堆栈中删除过多的数据元素,以下程序中的remove函数返回最顶部元素。

class Stack:

    def __init__(self):
        self.stack=[]

    def add(self, dataval):
# 使用列表追加方法添加元素
        if dataval not in self.stack:
            self.stack.append(dataval)
            return True
        else:
            return False
# 使用 peek 查看栈顶

    def peek(self):     
	    return self.stack[-1]

AStack=Stack()
AStack.add("Mon")
AStack.add("Tue")
AStack.peek()
print(AStack.peek())
AStack.add("Wed")
AStack.add("Thu")
print(AStack.peek())
Thu
Wed

祝学习愉快!(内容编辑有误?请选中要编辑内容 -> 右键 -> 修改 -> 提交!)

教程推荐

AI 音视频创作入门课 -〔唐子轩〕

快手 · 移动端音视频开发实战 -〔展晓凯〕

自动化测试高手课 -〔柳胜〕

超级访谈:对话张雪峰 -〔张雪峰〕

代码之丑 -〔郑晔〕

软件设计之美 -〔郑晔〕

说透敏捷 -〔宋宁〕

从0开发一款iOS App -〔朱德权〕

Service Mesh实践指南 -〔周晶〕

好记忆不如烂笔头。留下您的足迹吧 :)