鱼C论坛

 找回密码
 立即注册
查看: 2311|回复: 4

[已解决]第40课:类和对象,最后一题,如何 run?

[复制链接]
发表于 2021-2-23 10:00:20 | 显示全部楼层 |阅读模式

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

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

x
问题:请问此题,成功运行python后,怎么调用呀?我尝试了一些,都报错。

原题:
定义一个栈(Stack)类,用于模拟一种具有后进先出(LIFO)特性的数据结构。至少需要有以下方法:
方法名        含义
isEmpty()        判断当前栈是否为空(返回 True 或 False)
push()        往栈的顶部压入一个数据项
pop()        从栈顶弹出一个数据项(并在栈中删除)
top()        显示当前栈顶的一个数据项
bottom()        显示当前栈底的一个数据项

标准答案:
  1. class Stack:
  2.     def __init__(self, start = []):
  3.     # 属于“魔法方法”,是Python自动产生的方法。
  4.     # __init__方法,在创建对象后,会被自动调用。
  5.    
  6.         self.stack = [] # 定义一个空的栈。
  7.         for x in start: # ?问1: 这必要吗?后面的code,不是定义了push函数了吗?
  8.             self.push(x) # 同上问题。

  9.     def isEmpty(self): #属于“人为自定义”的方法。判断当前栈是否为空(返回 True 或 False)
  10.         return not self.stack # ?问2:本句,为何并未按照题目要求,返回 True 或 False呢?

  11.     def push(self, obj):
  12.      # 属于“人为自定义”的方法。往栈的顶部压入一个数据项
  13.         self.stack.append(obj) # 向栈里面,按照“后进先出”的顺序,append一个obj

  14.     def pop(self):
  15.      # 属于“人为自定义”的方法。从栈顶弹出一个数据项(并在栈中删除)
  16.         if not self.stack:
  17.          # ?问3:这是个简略表达吗?等同于:if self.stack == [] 空列表的意思?
  18.             print('警告:栈为空!')
  19.         else:
  20.              return self.stack.pop()
  21.              # 从栈里面,按照“后进先出”的顺序,pop出一个obj

  22.     def top(self):
  23.      # 属于“人为自定义”的方法。显示当前栈顶的一个数据项
  24.         if not self.stack:
  25.              print('警告:栈为空!')
  26.         else:
  27.              return self.stack[0]
  28.              # ? 问4:这里如果用 print(self.stack[0]),也行吧?

  29.     def bottom(self):
  30.      # 属于“人为自定义”的方法。显示当前栈底的一个数据项
  31.         if not self.stack:
  32.              print('警告:栈为空!')
  33.         else:
  34.              return self.stack[0]
复制代码
最佳答案
2021-2-23 16:51:01
本帖最后由 jackz007 于 2021-2-23 16:53 编辑

         问题1:在定义 Stack() 对象的时候,可以同时给出一个列表(或元组)型的参数 start,用于对对象进行初始化,如果这个参数省略,那么,对象的 stack 属性为空。在初始化对象时,使用了对象的 push 的方法。
         问题2、3:self . stack 本身就有逻辑值,如果 self . stack 中有元素存在,那么 self . stack 的逻辑值就是 True,那么,not self . stack 的值就是 False。在判断字符串、元组、列表、字典、集合等是否为空的时候,都可以采用这种方法。
         问题4:不可以,当然,如果你想在方法中打印元素的值是可以的,但是,return 是在返回函数值,而 print() 只是打印输出文字信息,如果用 print() 代替了 return 那么,top() 方法就会失去返回值,预期的功能也就随之丧失了。
         
         
         
     
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-2-23 16:51:01 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2021-2-23 16:53 编辑

         问题1:在定义 Stack() 对象的时候,可以同时给出一个列表(或元组)型的参数 start,用于对对象进行初始化,如果这个参数省略,那么,对象的 stack 属性为空。在初始化对象时,使用了对象的 push 的方法。
         问题2、3:self . stack 本身就有逻辑值,如果 self . stack 中有元素存在,那么 self . stack 的逻辑值就是 True,那么,not self . stack 的值就是 False。在判断字符串、元组、列表、字典、集合等是否为空的时候,都可以采用这种方法。
         问题4:不可以,当然,如果你想在方法中打印元素的值是可以的,但是,return 是在返回函数值,而 print() 只是打印输出文字信息,如果用 print() 代替了 return 那么,top() 方法就会失去返回值,预期的功能也就随之丧失了。
         
         
         
     
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-2-23 16:59:53 | 显示全部楼层
jackz007 发表于 2021-2-23 16:51
问题1:在定义 Stack() 对象的时候,可以同时给出一个列表(或元组)型的参数 start,用于对对象 ...

好的,多问一句,代码成功运行python后,怎么调用呀?能给我几段调用的代码,做例子么?我太傻了。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-2-23 17:25:16 | 显示全部楼层
本帖最后由 jackz007 于 2021-2-23 17:28 编辑
  1. class Stack:
  2.     def __init__(self, start = []):
  3.         self.stack = []
  4.         for x in start:  
  5.             self.push(x)

  6.     def isEmpty(self):
  7.         return not self.stack

  8.     def push(self, obj):
  9.         self.stack.append(obj)

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

  15.     def top(self):
  16.         if not self.stack:
  17.              print('警告:栈为空!')
  18.         else:
  19.              return self.stack[-1]           # 注意:原代码这里是错的

  20.     def bottom(self):
  21.         if not self.stack:
  22.              print('警告:栈为空!')
  23.         else:
  24.              return self.stack[0]
  25. if __name__ == '__main__':
  26.     s = Stack([1 , 2 , 3 , 4 , 5 , 6 , 7 , 8])
  27.     s . push(9)
  28.     print(s . stack)
  29.     print(s . bottom())
  30.     print(s . top())
  31.     s . push('A')
  32.     s . push('B')
  33.     s . push('C')
  34.     print(s . stack)
  35.     print(s . pop())
  36.     print(s . pop())
  37.     print(s . stack)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2021-2-24 14:52:32 | 显示全部楼层

高人,再次表示佩服。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-1 13:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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