|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 huyanmin 于 2021-3-11 17:25 编辑
class Stack:
def __init__(self, start=[]):
self.stack = []
for x in start: #此处for循环,在start列表改变后,再执行push方法,self.stack属性应该改变?
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]
s = Stack(('A' , 123 , 'ABC' , [1 , 2 , 3] , {'x' : 1 , 'Y' :2})) # 你的疑问答案在这里,遍历的目的,就是为了把这个元组数据装进对象的 stack 属性中。
print(s . stack)
s . push('XYZ') #词句不明白运行流程
print(s . pop())
print(s . pop())
print(s . stack)
#下面是对应运行结果
'''=== RESTART: C:/Users/admin/AppData/Local/Programs/Python/Python38/39.栈的操作.py ==
['A', 123, 'ABC', [1, 2, 3], {'x': 1, 'Y': 2}]
XYZ #不明白,为什么不是['A', 123, 'ABC', [1, 2, 3], {'x': 1, 'Y': 2},'XYZ']
{'x': 1, 'Y': 2}
['A', 123, 'ABC', [1, 2, 3]]'''
print(s . stack) --->打印一次原列表
s . push('XYZ') --->向列表末尾追加一个元素’XYZ‘
print(s . pop()) --->删除并返回列表最后一个元素,即’XYZ”
print(s . pop()) ---> 同上,返回{'x': 1, 'Y': 2}
print(s . stack) ----->再次打印列表
|
|