鱼C论坛

 找回密码
 立即注册
查看: 1655|回复: 2

[已解决]39讲最后一题代码不太理解有大佬讲解一下吗

[复制链接]
发表于 2020-10-8 04:43:02 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
class Stack:
    def __init__(self, start=[]):
        self.stack = []
        for x in start:
            self.push(x)

    def isEmpty(self):
        return not self.stack
   
    def push(self, obj):
        self.stack.append(obj)

    def pop(self):
        if not self.stack:
            print('警告:栈为空!')
        else:
            return self.stack.pop()

    def top(self):
        if not self.stack:
            print('警告:栈为空!')
        else:
            return self.stack[-1]

    def bottom(self):
        if not self.stack:
            print('警告:栈为空!')
        else:
            return self.stack[0]
for x in start: 的作用是什么
not self.stack 为空就会返回Tuer吗
最佳答案
2020-10-8 10:13:39
没做过这题,现做现卖一下,不对敬请指正。
这是一个用python实现数据结构中栈的操作,首先要了解栈的基本结构。可以简单的将栈理解成一个自顶而下的容器,最先添加的数据是在栈的最底层,越新添加的数据在栈的上层,当删除数据时,是从上往下逐个删除的。所以栈中数据的特点是“先进后出”,可能有点抽象,可以百度再了解一下。
这个题中,用stack列表模拟栈的操作,列表的第一个元素是栈的底,最后一个是栈的顶。
所以,for x in start,其实就是遍历向栈中添加数据的一个操作。push函数调用的是append方法,数据添加进stack列表的后面,达到不断添加数据、更新栈顶的操作。
pop函数调用pop()方法,返回的是列表的第一个元素,即栈底,如果没有,那么栈就是空的。
同理,top函数返回stack[-1],列表的最后一个元素,就是栈顶。
代码逻辑应该就是这样的,共同学习。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-10-8 10:13:39 | 显示全部楼层    本楼为最佳答案   
没做过这题,现做现卖一下,不对敬请指正。
这是一个用python实现数据结构中栈的操作,首先要了解栈的基本结构。可以简单的将栈理解成一个自顶而下的容器,最先添加的数据是在栈的最底层,越新添加的数据在栈的上层,当删除数据时,是从上往下逐个删除的。所以栈中数据的特点是“先进后出”,可能有点抽象,可以百度再了解一下。
这个题中,用stack列表模拟栈的操作,列表的第一个元素是栈的底,最后一个是栈的顶。
所以,for x in start,其实就是遍历向栈中添加数据的一个操作。push函数调用的是append方法,数据添加进stack列表的后面,达到不断添加数据、更新栈顶的操作。
pop函数调用pop()方法,返回的是列表的第一个元素,即栈底,如果没有,那么栈就是空的。
同理,top函数返回stack[-1],列表的最后一个元素,就是栈顶。
代码逻辑应该就是这样的,共同学习。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-10-8 23:20:13 | 显示全部楼层
Dragon.水魅 发表于 2020-10-8 10:13
没做过这题,现做现卖一下,不对敬请指正。
这是一个用python实现数据结构中栈的操作,首先要了解栈的基本 ...

谢谢大佬~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-31 02:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表