鱼C论坛

 找回密码
 立即注册
查看: 2353|回复: 3

[已解决]python 39,应该是['A', 123, 'ABC', [1, 2, 3], {'x': 1, 'Y': 2},'XYZ']

[复制链接]
发表于 2021-3-11 17:07:48 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 huyanmin 于 2021-3-11 17:25 编辑

class Stack:
    def __init__(self, start=[]):
        self.stack = []
        for x in start:  #此处for循环,在start列表改变后,再执行push方法,self.stack属性应该改变?
            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]




s = Stack(('A' , 123 , 'ABC' , [1 , 2 , 3] , {'x' : 1 , 'Y' :2}))  # 你的疑问答案在这里,遍历的目的,就是为了把这个元组数据装进对象的 stack 属性中。
print(s . stack)
s . push('XYZ')  #词句不明白运行流程
print(s . pop())
print(s . pop())
print(s . stack)


#下面是对应运行结果
'''=== RESTART: C:/Users/admin/AppData/Local/Programs/Python/Python38/39.栈的操作.py ==
['A', 123, 'ABC', [1, 2, 3], {'x': 1, 'Y': 2}]
XYZ  #不明白,为什么不是['A', 123, 'ABC', [1, 2, 3], {'x': 1, 'Y': 2},'XYZ']
{'x': 1, 'Y': 2}
['A', 123, 'ABC', [1, 2, 3]]'''
最佳答案
2021-3-11 17:37:54
print(s . stack)  --->打印一次原列表
s . push('XYZ')  --->向列表末尾追加一个元素’XYZ‘
print(s . pop()) --->删除并返回列表最后一个元素,即’XYZ”
print(s . pop())  ---> 同上,返回{'x': 1, 'Y': 2}
print(s . stack) ----->再次打印列表
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-3-11 17:34:26 | 显示全部楼层
我刚刚运行了下没问题呀。
s . push('XYZ')
它的作用就是向stack这个列表后面新增了‘XYZ“
这个对象就是重复了列表的一些操作呀push就是和list.append一样
pop()就是删除列表最后一个元素并返回该值
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2021-3-11 17:35:27 | 显示全部楼层
本帖最后由 jackz007 于 2021-3-11 17:39 编辑

       堆栈的特性就是后进先出,push() 相当于列表的 append() 方法,会把需要进栈的元素添加到 stack 的最后,实际上,在代码中也是这样实现的,而 pop() 方法则等同于列表的同名方法,代码中也是这么实现的。所以,pop() 方法从栈中弹出的就是位于堆栈尾部,最后进栈的那个元素,很显然,这个元素就是才用 s . push('XYZ') 语句入栈的字符串 'XYZ'。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-11 17:37:54 | 显示全部楼层    本楼为最佳答案   
print(s . stack)  --->打印一次原列表
s . push('XYZ')  --->向列表末尾追加一个元素’XYZ‘
print(s . pop()) --->删除并返回列表最后一个元素,即’XYZ”
print(s . pop())  ---> 同上,返回{'x': 1, 'Y': 2}
print(s . stack) ----->再次打印列表
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-9 16:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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