[python项目案例] 栈的封装、队列封装

一、栈的封装

在这里插入图片描述

栈(stack)又名堆栈,它是一种运算受限的线性表。限定仅在表尾进行插入和删除操作的线性表。这一端被称为栈顶,相对地,把另一端称为栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

要求功能:以列表作为输入元素,要求有:入栈,出栈,判断栈元素是否为空,求栈顶元素,求栈长度。

class Stack(object):
    """栈的封装[1, 2, 3]"""

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

    def push(self, value):
        """入栈"""
        self.stack.append(value)
        print(f"入栈元素为{value}")

    def pop(self):
        """出栈"""
        if self.is_empty():
            raise  Exception("栈为空")
        item = self.stack.pop()
        print(f"出栈元素为{item}")
        return  item

    def is_empty(self):
        """判断栈是否为空"""
        return  len(self.stack) == 0

    def top(self):
        """返回栈顶元素"""
        if self.is_empty():
            raise  Exception("栈为空")
        return  self.stack[-1]

    def __len__(self):
        """魔术方法, len(object)自动执行的方法"""
        return  len(self.stack)


#测试
if __name__ == '__main__':
    stack = Stack()
    stack.push(1)
    stack.push(2)
    stack.push(3)
    print(len(stack))                     # 3
    stack.pop()
    print(stack.is_empty())               # False
    print(stack.top())                    # 2
#结果
入栈元素为1
入栈元素为2
入栈元素为3
3
出栈元素为3
False
2

Process finished with exit code 0

二、队列的封装

在这里插入图片描述

队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。

要求功能:左侧作为队头,右侧作为队尾
入队,长度,出队,是否为空,队头,队尾。
在这里插入图片描述

class Stack(object):
    """队的封装基于列表[1, 2, 3, 4],左边作为栈底,右边作为栈顶"""

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

    def push(self, value):
        """入队"""
        self.stack.append(value)               #新元素加到最右边
        print(f"入队元素为{value}")

    def pop(self):
        """出队"""
        if self.is_empty():
            raise  Exception("队为空")         #设置出队元素为左边第一个
        item = self.stack.pop(0)
        print(f"出队元素为{item}")
        return  item

    def is_empty(self):
        """判断队是否为空"""
        return  len(self.stack) == 0

    def top(self):
        """队头"""
        if self.is_empty():
            raise  Exception("队为空")
        return  self.stack[0]

    def end(self):
        """队尾"""
        if self.is_empty():
            raise  Exception("队为空")
        return  self.stack[-1]

    def __len__(self):
        """魔术方法, len(object)自动执行的方法"""
        return  len(self.stack)

if __name__ == '__main__':
    stack = Stack()
    stack.push(1)
    stack.push(2)
    stack.push(3)
    print(len(stack))          # 3
    stack.pop()                #出队元素为1
    print(stack.is_empty())    # False
    print(stack.top())         # 2
    print(stack.end())         #3


#结果
入队元素为1
入队元素为2
入队元素为3
3
出队元素为1
False
2
3

Process finished with exit code 0

三、二叉树的封装

在这里插入图片描述

"""
二叉树:
    https://www.cnblogs.com/polly333/p/4740355.html
"""

class Node(object):
    """节点类"""
    def __init__(self, val=None, left=None, right=None):
        self.val = val
        self.left = left
        self.right = right

class BinaryTree(object):
    """封装二叉树"""
    def __init__(self, root):
        self.root = root

    def pre_travel(self, root):
        """先序遍历: 根左右"""
        if (root != None):
            print(root.val)
            self.pre_travel(root.left)
            self.pre_travel(root.right)


    def in_travel(self, root):
        """中序遍历: 左根右"""
        if (root != None):
            self.in_travel(root.left)
            print(root.val)
            self.in_travel(root.right)

    def last_travel(self, root):
        """后序遍历: 左右根"""
        if (root != None):
            self.last_travel(root.left)
            self.last_travel(root.right)
            print(root.val)


if __name__ == '__main__':
    node1 = Node(1)
    node2 = Node(2)
    node3 = Node(3)
    node4 = Node(4)
    node5 = Node(5)
    node6 = Node(6)
    node7 = Node(7)
    node8 = Node(8)
    node9 = Node(9)
    node10 = Node(10)

    bt = BinaryTree(root=node1)
    node1.left = node2
    node1.right = node3
    node2.left = node4
    node2.right= node5
    node3.left = node6
    node3.right = node7
    node4.left = node8
    node4.right = node9
    node5.left = node10


    # 先序遍历
    bt.pre_travel(node1)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值