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

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

技术教程推荐

朱赟的技术管理课 -〔朱赟〕

人工智能基础课 -〔王天一〕

编辑训练营 -〔总编室〕

检索技术核心20讲 -〔陈东〕

陶辉的网络协议集训班02期 -〔陶辉〕

Web漏洞挖掘实战 -〔王昊天〕

云原生架构与GitOps实战 -〔王炜〕

零基础GPT应用入门课 -〔林健(键盘)〕

程序员职业规划手册 -〔雪梅〕

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