鱼C论坛

 找回密码
 立即注册
查看: 1145|回复: 6

[已解决]039课后习题栈类

[复制链接]
发表于 2020-6-26 15:22:21 | 显示全部楼层 |阅读模式

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

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

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]

这个代码主要是模拟栈的压入和弹出的,要是我想压入fish这个单词,是不是应该在实例化时给start赋值为‘hsif’,之后压入栈中,之后按顺序弹出元素分别是f,i,s,h啊?
最佳答案
2020-6-26 15:26:09
本帖最后由 Twilight6 于 2020-6-26 15:30 编辑



楼上说的对,我觉的你应该是想这样的:

记着栈是 先进后出 ,后进先出的原则就好了

你如果想分别压入 f i s h ,那么按顺序来看  是 f -> i -> s -> h  f 是最先放入栈中的  

如果你取出,则顺序是  h -> s -> i -> f 这样的

所以你分别压入 h s i f 才是分别弹出  f i s h

如果你压入 fish  那么 弹出也为 fish 了

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-6-26 15:23:41 | 显示全部楼层
你对列表是不是有点误解啊?
弹出的是列表的一个元素,不是列表的元素的元素。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-26 15:26:09 | 显示全部楼层    本楼为最佳答案   
本帖最后由 Twilight6 于 2020-6-26 15:30 编辑



楼上说的对,我觉的你应该是想这样的:

记着栈是 先进后出 ,后进先出的原则就好了

你如果想分别压入 f i s h ,那么按顺序来看  是 f -> i -> s -> h  f 是最先放入栈中的  

如果你取出,则顺序是  h -> s -> i -> f 这样的

所以你分别压入 h s i f 才是分别弹出  f i s h

如果你压入 fish  那么 弹出也为 fish 了

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

使用道具 举报

发表于 2020-6-26 15:59:41 | 显示全部楼层
是的。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-6-26 16:36:13 | 显示全部楼层
Twilight6 发表于 2020-6-26 15:26
楼上说的对,我觉的你应该是想这样的:

记着栈是 先进后出 ,后进先出的原则就好了

fish入栈顺序是f>i>s>h,f在栈底,h在栈顶,出栈是h>s>i>f,对吧,之后打印的话,从上到下是fish对吧,是这个意思吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-26 16:54:59 | 显示全部楼层
lingedu 发表于 2020-6-26 16:36
fish入栈顺序是f>i>s>h,f在栈底,h在栈顶,出栈是h>s>i>f,对吧,之后打印的话,从上到下是fish对吧,是 ...
fish入栈顺序是f>i>s>h,f在栈底,h在栈顶,出栈是h>s>i>f,对吧


对的

之后打印的话,从上到下是fish对吧,是这个意思吗?


从上到下 应该是 hsif ,不是 fish,你自己都理解了 h 是栈顶 怎么就从上到下变回 fish 了呢哈哈
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-6-26 16:58:58 | 显示全部楼层

啊对,先打印的是栈顶
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-20 05:59

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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