Python-栈的封装,队列的封装,二叉树的封装

项目案例:栈的封装

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

class Stack:
    """栈的封装"""
    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}")

    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))
    stack.pop()
    print(stack.is_empty())
    print(stack.top())

执行结果如下:
在这里插入图片描述

项目案例:队列的封装

在这里插入图片描述

class Queue:
    def __init__(self):
        self.queue = []

    def enqueue(self,value):
        #入队
        self.queue.append(value)
        print(f'进入队列的是{value}')

    def dequeue(self):
        #出队
        if len(self.queue) == 0:
            raise Exception('队列长度为0')
        item = self.queue.pop(0)
        print(f'出队列的是{item}')

    def is_empty(self):
        #判断是否为空
        return len(self.queue) == 0

    def __len__(self):
        #魔术方法:获取队列长度
        return len(self.queue)

    def first(self):
        #获取队头元素
        if len(self.queue) == 0:
            raise Exception('队列长度为0')
        return self.queue[0]

    def last(self):
        #获取队尾元素
        if len(self.queue) == 0:
            raise Exception('队列长度为0')
        return self.queue[-1]

if __name__ == '__main__':
    queue = Queue()
    queue.enqueue(1)
    queue.enqueue(2)
    queue.enqueue(3)
    queue.dequeue()
    print(queue.last())
    print(queue.first())
    print(queue.is_empty())
    print(len(queue))

执行结果如下:
在这里插入图片描述

二叉树的封装

在这里插入图片描述

class Node:
#节点的封装
    def __init__(self,value=None,left=None,right=None):
        self.value = value
        self.left = left
        self.right = right


class Bt:
    def __init__(self,root):
        self.root = root

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


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 = Bt(root=node1)
    node1.left = node2
    node2.left = node4
    node4.left = node8
    node4.right = node9
    node2.right = node5
    node5.left = node10
    node1.right = node3
    node3.left = node6
    node3.right = node7

   #先序遍历
    bt.pre_travel(root=node1)

拓展:

#接上文,中序遍历,左根右
    def in_travel(self,root):
        if root != None:
            self.in_travel(root.left)
            print(root.value)
            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.value)
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C语言二叉树队列实验是一个经典且重要的实验项目。这个项目的目的是掌握二叉树队列的基本概念和操作。 首先,二叉树是一种常见的数据结构,它由节点组成,每个节点最多有两个子节点。树的根节点没有父节点,而其他节点有且仅有一个父节点。二叉树可以用于解决许多实际问题,比如表示层次结构、搜索和排序等。 在二叉树的实验中,我们需要实现一些基本的操作,如创建树、插入节点、搜索节点、删除节点等。我们可以使用递归或迭代的方法来实现这些操作。此外,还可以使用前序、中序或后序遍历二叉树,以及层次遍历等方法来访问树中的节点。 其次,是一个后进先出(LIFO)的数据结构。通过,我们可以实现某些算法和数据结构,比如深度优先搜索、中缀转后缀表达式等。在的实验中,我们需要实现一些基本的操作,如入、出、判断空或满等。 最后,队列是一个先进先出(FIFO)的数据结构。通过队列,我们可以实现某些算法和数据结构,比如广度优先搜索、消息传递等。在队列的实验中,我们需要实现一些基本的操作,如入队、出队、判断队空或队满等。 总之,C语言二叉树队列实验是一个很好的练习项目,可以加强我们对这些基本数据结构的理解和使用。通过完成这个实验,我们可以提高我们的编程技能,并在以后的编程实践中更好地应用这些知识。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值