第40课:类和对象,最后一题,如何 run?
问题:请问此题,成功运行python后,怎么调用呀?我尝试了一些,都报错。原题:
定义一个栈(Stack)类,用于模拟一种具有后进先出(LIFO)特性的数据结构。至少需要有以下方法:
方法名 含义
isEmpty() 判断当前栈是否为空(返回 True 或 False)
push() 往栈的顶部压入一个数据项
pop() 从栈顶弹出一个数据项(并在栈中删除)
top() 显示当前栈顶的一个数据项
bottom() 显示当前栈底的一个数据项
标准答案:
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
# ? 问4:这里如果用 print(self.stack),也行吧?
def bottom(self):
# 属于“人为自定义”的方法。显示当前栈底的一个数据项
if not self.stack:
print('警告:栈为空!')
else:
return self.stack 本帖最后由 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() 方法就会失去返回值,预期的功能也就随之丧失了。
jackz007 发表于 2021-2-23 16:51
问题1:在定义 Stack() 对象的时候,可以同时给出一个列表(或元组)型的参数 start,用于对对象 ...
好的,多问一句,代码成功运行python后,怎么调用呀?能给我几段调用的代码,做例子么?我太傻了。 本帖最后由 jackz007 于 2021-2-23 17:28 编辑
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
if __name__ == '__main__':
s = Stack()
s . push(9)
print(s . stack)
print(s . bottom())
print(s . top())
s . push('A')
s . push('B')
s . push('C')
print(s . stack)
print(s . pop())
print(s . pop())
print(s . stack) jackz007 发表于 2021-2-23 17:25
高人,再次表示佩服。
页:
[1]