鱼C论坛

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

[已解决]039课后作业疑问

[复制链接]
发表于 2017-3-23 13:40:10 | 显示全部楼层 |阅读模式

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

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

x
  1. 0.        定义一个栈(Stack)类,用于模拟一种具有后进先出(LIFO)特性的数据结构。至少需要有以下方法:
  2. isEmpty() 判断当前栈是否为空(返回True或False)
  3. push() 往栈的顶部压入一个数据项
  4. pop() 从栈顶弹出一个数据项(并在栈中删除)
  5. top() 显示当前栈的一个数据项
  6. bottom() 显示当前栈底的一个数据项
  7. class Stack:
  8.         def __init__(self,start=[]):
  9.                 self.stack = []
  10.                 for x in start:
  11.                         self.push(x)
  12.         def isEmpty(self):
  13.                 return not self.stack
  14.         def push(self,obj):
  15.                 self.stack.append(obj)
  16.         def pop(self):
  17.                 if not self.stack:
  18.                         print('警告:栈为空!')
  19.                 else:
  20.                         return self.stack.pop()

  21.         def top(self):
  22.                 if not self.stack:
  23.                         print('警告:栈为空!')
  24.                 else:
  25.                         return self.stack[-1]
  26.         def bottom(self):
  27.                 if not self.stack:
  28.                         print('警告:栈为空')
  29.                 else:
  30.                         return self.stack[0]
复制代码

for x in start:
                        self.push(x)

这段代码该如何理解?是用了组合吗?
最佳答案
2017-3-23 16:49:52
这个地方使用了迭代器,start是个列表,用for x in start 每次循环会把start中的一个元素读出来赋值给x,直到元素全部读取完毕才终止循环,然后调用push方法入栈
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-3-23 16:49:52 | 显示全部楼层    本楼为最佳答案   
这个地方使用了迭代器,start是个列表,用for x in start 每次循环会把start中的一个元素读出来赋值给x,直到元素全部读取完毕才终止循环,然后调用push方法入栈
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-3-23 20:58:46 | 显示全部楼层
lumber2388779 发表于 2017-3-23 16:49
这个地方使用了迭代器,start是个列表,用for x in start 每次循环会把start中的一个元素读出来赋值给x,直 ...

貌似学到这里的时候 还没讲到迭代器的内容。。。 谢谢你的解释
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-19 02:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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