|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 Peteryo01223 于 2021-2-22 16:22 编辑
原题: 定义一个栈(Stack)类,用于模拟一种具有后进先出(LIFO)特性的数据结构。至少需要有以下方法:
方法名 含义
isEmpty() 判断当前栈是否为空(返回 True 或 False)
push() 往栈的顶部压入一个数据项
pop() 从栈顶弹出一个数据项(并在栈中删除)
top() 显示当前栈顶的一个数据项
bottom() 显示当前栈底的一个数据项
标准答案 + 我自己写的注释:
[code]class stack:
def __init__(self, start = []):
# 属于“魔法方法”,是Python自动产生的方法。
# __init__方法,在创建对象后,会被自动调用。
self.stack = [] # 定义一个空的栈。
for x in start: # ?问1: 这必要吗?后面的code,不是定义了push函数了吗?
self.push(x) # 同上问题。
def isEmpty(self):
# 属于“人为自定义”的方法。判断当前栈是否为空(返回 True 或 False)
return not self.stack # ?问2:本句,为何并未按照题目要求,返回 True 或 False呢?
def push(self, obj):
# 属于“人为自定义”的方法。往栈的顶部压入一个数据项
self.stack.append(obj) # 向栈里面,按照“后进先出”的顺序,append一个obj
def pop(self):
# 属于“人为自定义”的方法。从栈顶弹出一个数据项(并在栈中删除)
if not self.stack:
# ?问3:这是个简略表达吗?等同于:if self.stack == [] 空列表的意思?
print('警告:栈为空!')
else:
return self.stack.pop()
# 从栈里面,按照“后进先出”的顺序,pop出一个obj
def top(self):
# 属于“人为自定义”的方法。显示当前栈顶的一个数据项
if not self.stack:
print('警告:栈为空!')
else:
return self.stack[0]
# ? 问4:这里如果用 print(self.stack[0]),也行吧?
def bottom(self):
# 属于“人为自定义”的方法。显示当前栈底的一个数据项
if not self.stack:
print('警告:栈为空!')
else:
return self.stack[0]
# ? 问5:以上code,运行后如何调用呢?请给几个实例。
5个小问题,总结如下:
问1:第7行和第8行code,必要吗?后面的code,不是定义了push函数了吗?
问2:第12行,为何并未按照题目要求,返回 True 或 False呢?
问3:第21行,是个简略表达吗?等同于:if self.stack == [] 空列表的意思?
问4:第32行,如果用 print(self.stack[0]),也行吧?
问5:以上code,运行后如何调用呢?请您帮助,展示几个实例吧,谢谢。[/
高手们回复后,预计18:00前,我第一时间给”最佳“。感谢您的耐心解答~
问1: for x in start 是遍历列表start中的元素 , 然后将每一个元素x用push压入栈中
问2: self.stack返回自身init后生成的stack, 如果为空(空就是False), 前面加上 not 那么就是True, return not self.stack就是return True, 如果不为空, self.stack 和 not 进行运算返回False.
问3 : 对的原理和问2相似
问4 : 不一样, return不等于print, 新手一定要理解, 一个是返回(供别的函数/表达式使用), 一个是输出到屏幕
问5 :
- stack stack_a(1, 2, 3)#创建实例stack_a
- print(stack_a.isEmpty())#判断当前栈是否为空,并将结果打印
- stack_a.push(4)#将4入栈
- print(stack.top())#显示当前栈顶的一个数据项, 注意我这里将top()的返回值作为print的参数使用
- if stack.top() == 1#这里演示将top()的返回值作为if表达式的一部分使用
- print(haha)
复制代码
|
|