欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python數(shù)據(jù)結(jié)構(gòu)棧實現(xiàn)進制轉(zhuǎn)換簡單示例

 更新時間:2023年02月03日 11:59:57   作者:西召  
眾所周知計算機的內(nèi)存都是以二進制的形式進行數(shù)據(jù)存儲,下面這篇文章主要給大家介紹了關(guān)于Python數(shù)據(jù)結(jié)構(gòu)棧實現(xiàn)進制轉(zhuǎn)換的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下

棧是一種后進先出(LIFO)的數(shù)據(jù)結(jié)構(gòu),在實際生活和工作中也很常見。

比如,在餐廳里的一摞盤子,總是從上面先取,也就是最后放到上面的先被取走。再比如,瀏覽網(wǎng)頁的時候,通過瀏覽器的回退按鈕訪問之前瀏覽過的網(wǎng)頁,也是最后訪問的先被獲取到。這些存儲結(jié)構(gòu),都可以稱之為棧。

下面是通過Python的數(shù)組實現(xiàn)的棧結(jié)構(gòu)源碼:

# 數(shù)據(jù)結(jié)構(gòu):通過Python數(shù)組實現(xiàn)棧
class Stack:
    def __init__(self):
        self.items = []

    # 檢查棧是否為空。它不需要參數(shù),且會返回一個布爾值。
    def is_empty(self):
        return self.items == []

    # 將一個元素添加到棧的頂端。它需要一個參數(shù)item,且無返回值。
    def push(self, item):
        self.items.append(item)

    # 將棧頂端的元素移除。它不需要參數(shù),但會返回頂端的元素,并且修改棧的內(nèi)容。
    def pop(self):
        return self.items.pop()

    # 返回棧頂端的元素,但是并不移除該元素。它不需要參數(shù),也不會修改棧的內(nèi)容。
    def peek(self):
        return self.items[len(self.items) - 1]

    # 返回棧中元素的數(shù)目。它不需要參數(shù),且會返回一個整數(shù)。
    def size(self):
        return len(self.items)

我們可以通過棧結(jié)構(gòu),來做數(shù)字進制的轉(zhuǎn)換。

我們通常生活中使用的是十進制,而在計算機世界,二進制才是通用的語言。

通過取余的方式,我們可以實現(xiàn)從十進制到二進制的轉(zhuǎn)換,十進制轉(zhuǎn)八進制也是同理。

下面是實現(xiàn)的源碼:

import my_stack

# 十進制轉(zhuǎ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

# 十進制:5 轉(zhuǎn)為二進制是:101
print(divide_by_2(5))

總結(jié)

到此這篇關(guān)于Python數(shù)據(jù)結(jié)構(gòu)棧實現(xiàn)進制轉(zhuǎn)換的文章就介紹到這了,更多相關(guān)Python數(shù)據(jù)結(jié)構(gòu)棧進制轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python如何獲取tensor()數(shù)據(jù)類型中的值

    python如何獲取tensor()數(shù)據(jù)類型中的值

    這篇文章主要介紹了python如何獲取tensor()數(shù)據(jù)類型中的值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 解決Keras 與 Tensorflow 版本之間的兼容性問題

    解決Keras 與 Tensorflow 版本之間的兼容性問題

    今天小編就為大家分享一篇解決Keras 與 Tensorflow 版本之間的兼容性問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • PO模式在selenium自動化測試框架的優(yōu)勢

    PO模式在selenium自動化測試框架的優(yōu)勢

    大家都知道po模式可以提高代碼的可讀性和減少了代碼的重復(fù),但是相對的缺點還有,今天通過本文一起學(xué)習(xí)下PO模式在selenium自動化測試框架的優(yōu)勢,需要的朋友可以參考下
    2022-03-03
  • vim自動補全插件YouCompleteMe(YCM)安裝過程解析

    vim自動補全插件YouCompleteMe(YCM)安裝過程解析

    這篇文章主要介紹了vim自動補全插件YouCompleteMe(YCM)安裝過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • python實現(xiàn)圖書借閱系統(tǒng)

    python實現(xiàn)圖書借閱系統(tǒng)

    這篇文章主要為大家詳細介紹了python實現(xiàn)圖書借閱系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • Python基于TensorFlow接口實現(xiàn)深度學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)回歸

    Python基于TensorFlow接口實現(xiàn)深度學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)回歸

    這篇文章主要為大家詳細介紹了如何基于Python語言中TensorFlow的tf.estimator接口,實現(xiàn)深度學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)回歸的具體方法,感興趣的可以了解一下
    2023-02-02
  • 詳解從Django Allauth中進行登錄改造小結(jié)

    詳解從Django Allauth中進行登錄改造小結(jié)

    這篇文章主要介紹了從 Django Allauth 中進行登錄改造小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • python 詳解如何寫flask文件下載接口

    python 詳解如何寫flask文件下載接口

    Flask是一個使用 Python 編寫的輕量級 Web 應(yīng)用框架。其 WSGI 工具箱采用 Werkzeug ,模板引擎則使用 Jinja2 。Flask使用 BSD 授權(quán)。Flask也被稱為 "microframework" ,因為它使用簡單的核心,用 extension 增加其他功能。Flask沒有默認使用的數(shù)據(jù)庫、窗體驗證工具
    2021-10-10
  • Python數(shù)據(jù)處理Filter函數(shù)高級用法示例

    Python數(shù)據(jù)處理Filter函數(shù)高級用法示例

    本文將詳細介紹filter函數(shù)的使用方法,并提供豐富的示例代碼,幫助你深入理解如何利用它來處理數(shù)據(jù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • 分享一下如何編寫高效且優(yōu)雅的 Python 代碼

    分享一下如何編寫高效且優(yōu)雅的 Python 代碼

    這篇文章主要介紹了分享一下如何編寫高效且優(yōu)雅的 Python 代碼,需要的朋友可以參考下
    2017-09-09

最新評論