Python數(shù)據(jù)結(jié)構(gòu)棧實(shí)現(xiàn)進(jìn)制轉(zhuǎn)換簡單示例
棧是一種后進(jìn)先出(LIFO)的數(shù)據(jù)結(jié)構(gòu),在實(shí)際生活和工作中也很常見。
比如,在餐廳里的一摞盤子,總是從上面先取,也就是最后放到上面的先被取走。再比如,瀏覽網(wǎng)頁的時(shí)候,通過瀏覽器的回退按鈕訪問之前瀏覽過的網(wǎng)頁,也是最后訪問的先被獲取到。這些存儲(chǔ)結(jié)構(gòu),都可以稱之為棧。
下面是通過Python的數(shù)組實(shí)現(xiàn)的棧結(jié)構(gòu)源碼:
# 數(shù)據(jù)結(jié)構(gòu):通過Python數(shù)組實(shí)現(xiàn)棧 class Stack: def __init__(self): self.items = [] # 檢查棧是否為空。它不需要參數(shù),且會(huì)返回一個(gè)布爾值。 def is_empty(self): return self.items == [] # 將一個(gè)元素添加到棧的頂端。它需要一個(gè)參數(shù)item,且無返回值。 def push(self, item): self.items.append(item) # 將棧頂端的元素移除。它不需要參數(shù),但會(huì)返回頂端的元素,并且修改棧的內(nèi)容。 def pop(self): return self.items.pop() # 返回棧頂端的元素,但是并不移除該元素。它不需要參數(shù),也不會(huì)修改棧的內(nèi)容。 def peek(self): return self.items[len(self.items) - 1] # 返回棧中元素的數(shù)目。它不需要參數(shù),且會(huì)返回一個(gè)整數(shù)。 def size(self): return len(self.items)
我們可以通過棧結(jié)構(gòu),來做數(shù)字進(jìn)制的轉(zhuǎn)換。
我們通常生活中使用的是十進(jìn)制,而在計(jì)算機(jī)世界,二進(jìn)制才是通用的語言。
通過取余的方式,我們可以實(shí)現(xiàn)從十進(jìn)制到二進(jìn)制的轉(zhuǎn)換,十進(jìn)制轉(zhuǎn)八進(jìn)制也是同理。
下面是實(shí)現(xiàn)的源碼:
import my_stack # 十進(jìn)制轉(zhuǎn)二進(jìn)制 def divide_by_2(number): stack = my_stack.Stack() while number > 0: temp = number % 2 stack.push(temp) number = number // 2 binStr = '' while not stack.is_empty(): binStr = binStr + str(stack.pop()) return binStr # 十進(jìn)制:5 轉(zhuǎn)為二進(jìn)制是:101 print(divide_by_2(5))
總結(jié)
到此這篇關(guān)于Python數(shù)據(jù)結(jié)構(gòu)棧實(shí)現(xiàn)進(jìn)制轉(zhuǎn)換的文章就介紹到這了,更多相關(guān)Python數(shù)據(jù)結(jié)構(gòu)棧進(jìn)制轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python如何獲取tensor()數(shù)據(jù)類型中的值
這篇文章主要介紹了python如何獲取tensor()數(shù)據(jù)類型中的值,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07解決Keras 與 Tensorflow 版本之間的兼容性問題
今天小編就為大家分享一篇解決Keras 與 Tensorflow 版本之間的兼容性問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02PO模式在selenium自動(dòng)化測試框架的優(yōu)勢
大家都知道po模式可以提高代碼的可讀性和減少了代碼的重復(fù),但是相對的缺點(diǎn)還有,今天通過本文一起學(xué)習(xí)下PO模式在selenium自動(dòng)化測試框架的優(yōu)勢,需要的朋友可以參考下2022-03-03vim自動(dòng)補(bǔ)全插件YouCompleteMe(YCM)安裝過程解析
這篇文章主要介紹了vim自動(dòng)補(bǔ)全插件YouCompleteMe(YCM)安裝過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10python實(shí)現(xiàn)圖書借閱系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)圖書借閱系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02Python基于TensorFlow接口實(shí)現(xiàn)深度學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)回歸
這篇文章主要為大家詳細(xì)介紹了如何基于Python語言中TensorFlow的tf.estimator接口,實(shí)現(xiàn)深度學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)回歸的具體方法,感興趣的可以了解一下2023-02-02詳解從Django Allauth中進(jìn)行登錄改造小結(jié)
這篇文章主要介紹了從 Django Allauth 中進(jìn)行登錄改造小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12Python數(shù)據(jù)處理Filter函數(shù)高級(jí)用法示例
本文將詳細(xì)介紹filter函數(shù)的使用方法,并提供豐富的示例代碼,幫助你深入理解如何利用它來處理數(shù)據(jù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11