日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python中的栈结构_Python可以实现栈的结构吗

發(fā)布時間:2023/12/15 python 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python中的栈结构_Python可以实现栈的结构吗 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

棧(stack)又名堆棧,它是一種運算受限的線性表。在Python中可使用列表進行實現(xiàn)。

什么是棧?

棧(stack)又名堆棧,它是一種運算受限的線性表。其限制是僅允許在表的一端進行插入和刪除運算。這一端被稱為棧頂,相對地,把另一端稱為棧底。向一個棧插入新元素又稱作進棧、入棧或壓棧,它是把新元素放到棧頂元素的上面,使之成為新的棧頂元素;從一個棧刪除元素又稱作出棧或退棧,它是把棧頂元素刪除掉,使其相鄰的元素成為新的棧頂元素。

如何實現(xiàn)?

在Python中使用列表來實現(xiàn):#!/usr/bin/env python

#定義一個列表來模擬棧

stack = []

#進棧,調(diào)用列表的append()函數(shù)加到列表的末尾,strip()沒有參數(shù)是去掉首尾的空格

def pushit():

stack.append(raw_input('Enter new string: ').strip())

#出棧,用到了pop()函數(shù)

def popit():

if len(stack) == 0:

print 'Cannot pop from an empty stack!'

else:

print 'Removed [', stack.pop(), ']'

#編歷棧

def viewstack():

print stack

#CMDs是字典的使用

CMDs = {'u': pushit, 'o': popit, 'v': viewstack}

#pr為提示字符

def showmenu():

pr = """

p(U)sh

p(O)p

(V)iew

(Q)uit

Enter choice: """

while True:

while True:

try:

#先用strip()去掉空格,再把第一個字符轉(zhuǎn)換成小寫的

choice = raw_input(pr).strip()[0].lower()

except (EOFError, KeyboardInterrupt, IndexError):

choice = 'q'

print '\nYou picked: [%s]' % choice

if choice not in 'uovq':

print 'Invalid option, try again'

else:

break

#CMDs[]根據(jù)輸入的choice從字典中對應相應的value,比如說輸入u,從字典中得到value為pushit,執(zhí)行pushit()進棧操作

if choice == 'q':

break

CMDs[choice]()

#判斷是否是從本文件進入,而不是被調(diào)用

if __name__ == '__main__':

showmenu()

實例內(nèi)容擴展:# -*- coding:utf-8 -*-

# __author__ :kusy

# __content__:文件說明

# __date__:2018/9/30 17:28

class MyStack(object):

def __init__(self):

self.stack_list = []

self.count = 0

# 創(chuàng)建一個棧

def create_stack(self):

return self.stack_list

# 棧中添加值

def push(self, value):

self.stack_list.insert(0,value)

self.count += 1

#返回棧頂元素值

def peek(self):

if self.count:

return self.stack_list[0]

# 刪除棧頂元素

def pop(self):

self.stack_list.pop(0)

self.count -= 1

# 返回棧是否為空

def is_empty(self):

return self.count == 0

#打印棧內(nèi)容

def print_all(self):

for sl in self.stack_list:

print(sl)

if __name__ == '__main__':

ms = MyStack()

ms.create_stack()

ms.push(1)

ms.push(2)

ms.push(3)

print('棧元素:')

ms.print_all()

print('棧頂元素:',ms.peek())

ms.pop()

print('棧頂元素刪除后:')

ms.print_all()

print('棧是否為空:','是' if ms.is_empty() else '否')

print('---繼續(xù)刪除元素')

ms.pop()

print('---繼續(xù)刪除元素')

ms.pop()

print('棧是否為空:','是' if ms.is_empty() else '否')

運行結(jié)果如下C:\Users\suneee\AppData\Local\Programs\Python\Python36\python.exe E:/wangjz/PyWorkSpace/LearnPython/PY0929/stack.py

棧元素:

3

2

1

棧頂元素: 3

棧頂元素刪除后:

2

1

棧是否為空: 否

---繼續(xù)刪除元素

---繼續(xù)刪除元素

棧是否為空: 是

Process finished with exit code 0

到此這篇關于Python可以實現(xiàn)棧的結(jié)構(gòu)嗎的文章就介紹到這了,更多相關Python實現(xiàn)棧的結(jié)構(gòu)的條件內(nèi)容請搜索ZaLou.Cn

創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅持創(chuàng)作打卡瓜分現(xiàn)金大獎

總結(jié)

以上是生活随笔為你收集整理的python中的栈结构_Python可以实现栈的结构吗的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。