百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

栈的实现和应用-python3(栈的实现和应用的实验报告)

off999 2024-10-01 14:05 47 浏览 0 评论

前面两篇文章用C语言实现了栈(栈stack的数组和单链表实现 ),并对栈进行了应用(基于单链表实现的栈解题-LeetCode) 。

本篇文章将使用python3实现栈并进行解题。

首先定义一个栈的类,和栈的每一个节点的类。其中栈中包括他的top指针、他的大小和他的单个节点;单个节点中包括数据和相当于指向下一个节点的指针。

class Stack://栈的类

    class Node://栈的每一个节点的类
        def __init__(self, data, next):
            self._data = data//节点的数据域
            self._next = next//节点的指针域

    def __init__(self):
        self._top = None//栈的top指针
        self._size = 0//栈的大小

对栈的操作,我们先只定义三个简单的方法:StackPush()、StackPop()、IsStackEmpty():

先分析一下方法StackPush:

一行代码搞定,比较抽象,需要仔细理解:self._top = self.Node(data, self._top)

通俗的理解就是,新加入的节点作为栈的top节点,而新加入的节点的next的指针指向原来栈的top节点。

def StackPush(self, data):
        self._top = self.Node(data, self._top)
        self._size += 1
        //print("push:", data, "size:", self._size)

分析方法StackPop:

如果栈空就不需要弹出节点了,报出异常:

class StackEmptyException(Exception):  # 空栈时抛出异常
    pass
    
if self.IsStackEmpty():
            raise StackEmptyException('Error:trying to pop from empty stack')

把栈顶数据弹出,top指针指向下一个数据节点,栈的大小减1

 def Stackpop(self):
        if self.IsStackEmpty():
            raise StackEmptyException('Error:trying to pop from empty stack')
        ans = self._top._data
        self._top = self._top._next
        self._size -= 1
       // print("pop:", ans, "size:", self._size)
        return ans

分析方法IsStackEmpty()

栈的大小为0,则栈已经为空。

def IsStackEmpty(self):
        return self._size == 0


pyhton3 栈的代码清单如下:

class StackEmptyException(Exception):  # 空栈时抛出异常
    pass


class Stack:

    class Node:
        def __init__(self, data, next):
            self._data = data
            self._next = next

    def __init__(self):
        self._top = None
        self._size = 0

    def StackPush(self, data):
        self._top = self.Node(data, self._top)
        self._size += 1
        print("push:", data, "size:", self._size)

    def IsStackEmpty(self):
        return self._size == 0

    def Stackpop(self):
        if self.IsStackEmpty():
            raise StackEmptyException('Error:trying to pop from empty stack')
        ans = self._top._data
        self._top = self._top._next
        self._size -= 1
        print("pop:", ans, "size:", self._size)
        return ans

对栈进行应用,基于单链表实现的栈解题-LeetCode 中使用c语言编写了代码,我们使用python3改写一下:

代码清单见下:

class StackEmptyException(Exception):  # 空栈时抛出异常
    pass


class Stack:

    class Node:
        def __init__(self, data, next):
            self._data = data
            self._next = next

    def __init__(self):
        self._top = None
        self._size = 0

    def StackPush(self, data):
        self._top = self.Node(data, self._top)
        self._size += 1
        print("push:", data, "size:", self._size)

    def IsStackEmpty(self):
        return self._size == 0

    def Stackpop(self):
        if self.IsStackEmpty():
            raise StackEmptyException('Error:trying to pop from empty stack')
        ans = self._top._data
        self._top = self._top._next
        self._size -= 1
        print("pop:", ans, "size:", self._size)
        return ans


class Valid:
    def mach(self, c):
        if (c == '}'):
            return '{'
        elif (c == ')'):
            return '('
        elif (c == ']'):
            return '['
        else:
            return False

    def isValid(self, strings):
        stack = Stack()

        for string in strings:
            if(len(strings) % 2 != 0):
                return False
            if((string == '{') or (string == '(') or (string == '[')):
                Stack.StackPush(stack, string)
            else:
                if(Stack.IsStackEmpty(stack)):
                    return False
                if(self.mach(string)):
                    data = Stack.Stackpop(stack)
                    if(data != self.mach(string)):
                        return False
        return Stack.IsStackEmpty(stack)


if __name__ == "__main__":
    s = "[[[]]]{}"
    valid = Valid()
    ret = valid.isValid(s)
    print(ret)

数据结构系列:

栈stack的数组和单链表实现

基于单链表实现的栈解题-LeetCode

判断二叉树是否为平衡二叉树

平衡二叉树 构建平衡二叉树

如何优雅地画好二叉树

二叉树的层序遍历及应用

二叉树遍历的思维导图

平衡二叉树的结点删除操作

不平衡二叉树的旋转(LL、RR、LR、RL)

二叉查找树(BST:Binary Search Tree)


LeetCode系列:

确定有限状态机(DFA)-Leet

字符串转换成一个 32 位有符号整数-atoi 函数Leet

leetcode2. 两数相加-c语言-python3

LeetCode4. 寻找两个正序数组的中位数

LeetCode5.1-马拉车算法求解最长回文子串

LeetCode5.0-最长回文子串-中心扩展法-C语言

LeetCode5.2-动态规划求解最长回文子串

LeetCode7.翻转整数-C语言与python的异同点

相关推荐

手机上怎么找qq邮箱登录(用手机怎么找到qq邮箱)

入口是“联系人”选项卡。qq邮箱手机在QQ主菜单中选择下方的“联系人”选项卡;3、在“联系人”中选取“公众号”选项卡;4、在公众号中菜单中找到或搜索“QQ邮箱提醒”,点击进入;5、点击“进入邮箱”;6...

amd显卡控制面板

AMD显卡控制面板是用来管理你的AMD显卡的,可以在控制面板中进行设置一些简单的调整,来提升显卡性能和效果。1、先打开AMD控制面板。2、打开“垂直同步(V-SYNC)”功能,可调整细节,改善影像流畅...

win10老是未响应卡死(window10总是未响应)

具体方法:1、如果win10中的应用程序出现不响应的情况,应该是应用程序加载失败了。可以通过重置方法来解决win10应用程序无响应。2、登录win10系统,用管理员身份运行Powershell(可在C...

usb安装系统步骤(USB安装系统步骤)

1.准备一张U盘,将联想官网下载的系统镜像文件复制到U盘中;2.将U盘插入联想S41U电脑,重启电脑,按F12进入BIOS设置,将U盘设置为启动项;3.重启电脑,进入U盘安装界面,按提示操作,完成系统...

win98安装教程(win98iso怎么安装)

如何安装windows98  一、具体安装步骤  备份好重要文件之后,就可以安装windows98了。  第一步:启动安装程序。  用户如果原来已安装了windows95/97/98,现在拟对其进行升...

雨林木风win7安装(雨林木风win732位安装教程)

  安装步骤如下:  1、光盘放入光驱,复制光盘上的win7.gho和安装系统.exe到硬盘非C盘的文件夹;(gho文件名可以是其他名字,后缀为gho,体积最大的就是。)  2、双击安装系统.exe;...

win10解绑管理员账户(win10管理员账户怎么取消开机密码)

要解除Windows10电脑上的管理员权限,您需要进行以下操作:1.打开“控制面板”:右键单击“开始”按钮,然后选择“控制面板”。2.进入“用户账户”:在控制面板中,选择“用户账户”。3.点击...

win10家庭版没有组策略编辑器

Win10组策略编辑器找不到怎么办  解决方法  一、win10系统版本本身不提供组策略的功能。  1、运行gpedit.msc直接提示找到gpedit.msc(组策略)。  2、运行MMC,在“添加...

tplogin管理员登录入口(tplogin重新设置密码)

tplogin.cn是新版tplink路由器的登录地址(管理页面地址),在浏览器中输入tplogin.cn,就可以打开tplink路由器的管理页面(登录页面)。具体的登录方法如下:1、打开电脑上的浏...

psp模拟器怎么导入游戏(psp模拟器怎么导入游戏 Vivo手机)

方法如下:1、打开能操作文件的助手软件,用pp链接后点击左下文件,然后点常用目录下的程序用户,会出现ppsspp的文件夹。2、打开ppsspp文件夹,会出来四个选项文件夹,第一个进去后是psp文件夹,...

电脑系统怎样升级(电脑系统怎么升级)

电脑系统升级方法步骤,1、打开电脑,点击电脑左下角的开始菜单,在弹出的菜单选项中选择“控制面板”。2、点击“开始”,点击“控制面板”3、在控制面板中,点击“系统和安全”。4、点击启用或禁用自动更新。5...

win10正版系统下载网站(win10官方下载网站)
  • win10正版系统下载网站(win10官方下载网站)
  • win10正版系统下载网站(win10官方下载网站)
  • win10正版系统下载网站(win10官方下载网站)
  • win10正版系统下载网站(win10官方下载网站)
windows无法激活(windows无法激活有什么影响)

1.如果修复或重新组装了电脑,则可能是安装了不同版本的Windows。或者,如果在修复过程中为电脑使用了其他产品密钥,当使用该密钥的电脑数大于Microsoft软件许可条款允许的电脑数时,该密钥...

新机怎么激活windows10(新机怎么激活电池)
  • 新机怎么激活windows10(新机怎么激活电池)
  • 新机怎么激活windows10(新机怎么激活电池)
  • 新机怎么激活windows10(新机怎么激活电池)
  • 新机怎么激活windows10(新机怎么激活电池)
u盘文件恢复软件免费(恢复u盘数据免费的软件)
u盘文件恢复软件免费(恢复u盘数据免费的软件)

u盘损坏文件恢复方法:1、打开电脑桌面的“计算机”或“我的电脑”。2、然后再找到需要修复的u盘。3、打开“运行”窗口(可以直接按“Windows+R”快捷打开),输入“CMD”并点击“确定”按钮以进入命令提符界面。4、从打开的“命令提示符”...

2025-12-28 22:03 off999

取消回复欢迎 发表评论: