Python教程:堆栈数据操作

2018-10-1419:15:46数据结构与算法Comments2,988 views字数 1241阅读模式

英语词典中,堆(Stack)表示将对象放在另一个对象上。 在这个数据结构中分配内存的方式是一样的。 它以类似的方式存储数据元素,类似在厨房中一堆盘子:一个在另一个之上存放。 所以堆栈数据允许操作的一端可以称为栈顶。 可在栈顶上添加元素或仅从堆栈中移除元素。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/suanfa/6669.html

在堆栈中,顺序排列的最后一个元素将首先出现,因为只能从堆栈顶部移除。 这种功能称为后进先出(LIFO)功能。 添加和删除元素的操作称为PUSHPOP。 在下面的程序中,我们将它实现为addremove函数。首先声明一个空列表并使用append()pop()方法来添加和删除数据元素。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/suanfa/6669.html

推入堆栈文章源自菜鸟学院-https://www.cainiaoxueyuan.com/suanfa/6669.html

class Stack:

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

    def add(self, dataval):
# Use list append method to add element
        if dataval not in self.stack:
            self.stack.append(dataval)
            return True
        else:
            return False
# Use peek to look at the top of the stack

    def peek(self):     
        return self.stack[0]

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

执行上面示例代码,得到以下结果 -文章源自菜鸟学院-https://www.cainiaoxueyuan.com/suanfa/6669.html

Mon
Mon
Shell

堆栈移除文章源自菜鸟学院-https://www.cainiaoxueyuan.com/suanfa/6669.html

只能从堆栈中移除数据元素,下面实现了一个可以实现这一功能的python程序。 以下程序中的remove函数返回最上面的元素。 首先通过计算堆栈的大小来检查顶层元素,然后使用内置的pop()方法找出最顶层的元素。参考以下代码实现 -文章源自菜鸟学院-https://www.cainiaoxueyuan.com/suanfa/6669.html

class Stack:

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

    def add(self, dataval):
# Use list append method to add element
        if dataval not in self.stack:
            self.stack.append(dataval)
            return True
        else:
            return False

# Use list pop method to remove element
    def remove(self):
        if len(self.stack) <= 0:
            return ("No element in the Stack")
        else:
            return self.stack.pop()

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

执行上面示例代码,得到以下结果 -文章源自菜鸟学院-https://www.cainiaoxueyuan.com/suanfa/6669.html

Tue
Thu
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/suanfa/6669.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/suanfa/6669.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定