鱼C论坛

 找回密码
 立即注册
查看: 2525|回复: 1

[已解决]python 39课习题,求详解,

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

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

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

x
class Stack:
    def __init__(self, start=[]):
        self.stack = []  #此处为什么不这样,self.stack=start,这样就省去了下面两句
        for x in start:  #此处的start列表是形参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]
最佳答案
2021-3-10 10:34:50
本帖最后由 逃兵 于 2021-3-10 10:36 编辑

start是列表

字典,列表,集合都是不可哈希数据

如果按照你的想法进行修改,更改外部变量start

生成的实例会随着start的变化而变化,有时候会引发出乎我们意料的bug

  1. class Stack:
  2.     def __init__(self, start=[]):
  3.         self.stack=start
  4.     def isEmpty(self):
  5.         return not self.stack
  6.    
  7.     def push(self, obj):
  8.         self.stack.append(obj)

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

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

  19.     def bottom(self):
  20.         if not self.stack:
  21.             print('警告:栈为空!')
  22.         else:
  23.             return self.stack[0]
复制代码

  1. >>> start = []
  2. >>> a = Stack(start)
  3. >>> a.stack
  4. []
  5. >>> start.append(1)
  6. >>> a.stack
  7. [1]
  8. >>>
复制代码


使用迭代赋值的方法,生成的实例不会随着start的变化而变化

  1. >>> start = []
  2. >>> a = Stack(start)
  3. >>> a.stack
  4. []
  5. >>> start.append(1)
  6. >>> a.stack
  7. []
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-3-10 10:34:50 | 显示全部楼层    本楼为最佳答案   
本帖最后由 逃兵 于 2021-3-10 10:36 编辑

start是列表

字典,列表,集合都是不可哈希数据

如果按照你的想法进行修改,更改外部变量start

生成的实例会随着start的变化而变化,有时候会引发出乎我们意料的bug

  1. class Stack:
  2.     def __init__(self, start=[]):
  3.         self.stack=start
  4.     def isEmpty(self):
  5.         return not self.stack
  6.    
  7.     def push(self, obj):
  8.         self.stack.append(obj)

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

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

  19.     def bottom(self):
  20.         if not self.stack:
  21.             print('警告:栈为空!')
  22.         else:
  23.             return self.stack[0]
复制代码

  1. >>> start = []
  2. >>> a = Stack(start)
  3. >>> a.stack
  4. []
  5. >>> start.append(1)
  6. >>> a.stack
  7. [1]
  8. >>>
复制代码


使用迭代赋值的方法,生成的实例不会随着start的变化而变化

  1. >>> start = []
  2. >>> a = Stack(start)
  3. >>> a.stack
  4. []
  5. >>> start.append(1)
  6. >>> a.stack
  7. []
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-26 05:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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