亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python利用后綴表達(dá)式實(shí)現(xiàn)計算器功能

 更新時間:2021年02月22日 14:59:28   作者:ikalpa  
這篇文章主要為大家詳細(xì)介紹了python利用后綴表達(dá)式實(shí)現(xiàn)計算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了python實(shí)現(xiàn)計算器功能的具體代碼,供大家參考,具體內(nèi)容如下

前綴表達(dá)式

運(yùn)算符在數(shù)字的前面

1 + (2 + 3) * 4 - 5 (中綴)
- + 1 * + 2 3 4 5  (前綴)

前綴表達(dá)式的計算方法和后綴表達(dá)式類似,只是變成了從右往左掃描

中綴表達(dá)式

運(yùn)算符在中間,運(yùn)算時需要考慮運(yùn)算符優(yōu)先級

1+2*3-5
要先算2*3....

后綴表達(dá)式

運(yùn)算符在數(shù)字的后面,運(yùn)算時不考慮優(yōu)先級,只需要遇到符號,就把他前面的兩個數(shù)字進(jìn)行運(yùn)算就好了

例如: a b c + + 即: a + (b + c)

1 + (2 + 3) * 4 - 5 (中綴)
1 2 3 + 4 * + 5 -  (后綴)

因為無需考慮優(yōu)先級,運(yùn)算是線性結(jié)構(gòu)的,其用棧實(shí)現(xiàn)會很簡單

中綴表達(dá)式 轉(zhuǎn)換為 后綴表達(dá)式

運(yùn)算規(guī)律,運(yùn)算數(shù)位置不變,改變的是符號的位置

2 + 9 / 3 - 5   (中綴)
2 9 3 / + 5 -  (后綴)

具體方式

1.從左到右進(jìn)行遍歷
2.運(yùn)算數(shù),直接輸出.
3.左括號,直接壓入堆棧,(括號是最高優(yōu)先級,無需比較)(入棧后優(yōu)先級降到最低,確保其他符號正常入棧)
4.右括號,(意味著括號已結(jié)束)不斷彈出棧頂運(yùn)算符并輸出直到遇到左括號(彈出但不輸出)
5.運(yùn)算符,將該運(yùn)算符與棧頂運(yùn)算符進(jìn)行比較,
如果優(yōu)先級高于棧頂運(yùn)算符則壓入堆棧(該部分運(yùn)算還不能進(jìn)行),
如果優(yōu)先級低于等于棧頂運(yùn)算符則將棧頂運(yùn)算符彈出并輸出,然后比較新的棧頂運(yùn)算符.
(低于彈出意味著前面部分可以運(yùn)算,先輸出的一定是高優(yōu)先級運(yùn)算符,等于彈出是因為同等優(yōu)先級,從左到右運(yùn)算)
直到優(yōu)先級大于棧頂運(yùn)算符或者棧空,再將該運(yùn)算符入棧.
**6.*如果對象*處理完畢,則按順序彈出并輸出棧中所有運(yùn)算符.

后綴表達(dá)式運(yùn)算步驟

后綴表達(dá)式運(yùn)算步驟:

(以堆棧儲存)
從左到右,遇到運(yùn)算符就彈出相應(yīng)的運(yùn)算數(shù),運(yùn)算后再把結(jié)果入棧.最終結(jié)果就是棧頂數(shù)的值.
(由于該運(yùn)算為線性結(jié)構(gòu),具體運(yùn)算時是不需要儲存輸出后的運(yùn)算符,一般是輸出一個運(yùn)算符就進(jìn)行一次運(yùn)算,不像圖中要儲存輸出狀態(tài).)

注意點(diǎn):

有時候'-'(負(fù)號)是單目運(yùn)算符,則要修改運(yùn)算數(shù).
遇到其他運(yùn)算符(如冪運(yùn)算)也類似.

python代碼例子

'''
中綴轉(zhuǎn)換為后綴
'''

a = "1+(2+6/1+2)"
#a = "2+9/3-5"
# 可能出現(xiàn)的符號 
symbol_1 = ['+','-','*','/']
symbol_2 = ['(']
symbol_3 = [')']
# 符號的優(yōu)先級
priority = {'#':-1,'(':1,'+':2,'-':2,'*':3,'/':3}
match_2 = {')':'('}
# 存儲符號的棧
zhan = []
zhan.append("#")
# 結(jié)果
result = []

'''
### 這里只是對表達(dá)式進(jìn)行轉(zhuǎn)換
for i in a:
 # 如果是數(shù)字直接添加到結(jié)果
 if i.isdigit():
 result.append(i)
 # 如果是 + - * / 運(yùn)算,則先出棧更低優(yōu)先級的,然后入棧
 elif i in symbol_1:
 # 如果優(yōu)先級低,則出棧所有優(yōu)先級>=的符號
 while priority[i] <= priority[zhan[-1]]:
 result.append(zhan.pop())
 # 壓入符號
 zhan.append(i)
 # 如果是左括號,直接壓入
 elif i in symbol_2:
 zhan.append(i)
 # 如果是右括號,則出棧,直到遇到了匹配的左括號,然后吧左括號也出棧
 elif i in symbol_3:
 while zhan[-1] != match_2[i]:
 result.append(zhan.pop())
 zhan.pop()
 
result.append(zhan.pop())
print(''.join(result))

'''
# 下面通過將中綴表達(dá)式轉(zhuǎn)換為后綴表達(dá)式,并進(jìn)行運(yùn)算
def my_operation(symbol, a, b):
 a,b = int(a),int(b)
 if symbol == '+':
 return a + b
 elif symbol == '-':
 return a - b
 elif symbol == '*':
 return a * b
 elif symbol == '/':
 return a / b

def to_operation(result, zhan):
 two = result.pop()
 one = result.pop()
 symbol = zhan.pop()
 ret = my_operation(symbol, one, two)
 print(f"{one}{symbol}{two} = {ret}")
 result.append(ret)

### 在表達(dá)式轉(zhuǎn)換的時候就一邊進(jìn)行了運(yùn)算
for i in a:
 # 如果是數(shù)字直接添加到結(jié)果
 if i.isdigit():
 result.append(i)
 # 如果是 + - * / 運(yùn)算,則先出棧更低優(yōu)先級的,然后入棧
 elif i in symbol_1:
 # 如果優(yōu)先級低,則出棧所有優(yōu)先級>=的符號
 while priority[i] <= priority[zhan[-1]]:
 to_operation(result, zhan)
 # 壓入符號
 zhan.append(i)
 # 如果是左括號,直接壓入
 elif i in symbol_2:
 zhan.append(i)
 # 如果是右括號,則出棧,直到遇到了匹配的左括號,然后吧左括號也出棧
 elif i in symbol_3:
 while zhan[-1] != match_2[i]:
 to_operation(result, zhan)
 zhan.pop()
 
to_operation(result, zhan)
print(result)

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • pytorch中節(jié)約顯卡內(nèi)存的方法和技巧

    pytorch中節(jié)約顯卡內(nèi)存的方法和技巧

    顯存不足是很多人感到頭疼的問題,畢竟能擁有大量顯存的實(shí)驗室還是少數(shù),而現(xiàn)在的模型已經(jīng)越跑越大,模型參數(shù)量和數(shù)據(jù)集也越來越大,所以這篇文章給大家總結(jié)了一些pytorch中節(jié)約顯卡內(nèi)存的方法和技巧,需要的朋友可以參考下
    2023-11-11
  • Python進(jìn)程池log死鎖問題分析及解決

    Python進(jìn)程池log死鎖問題分析及解決

    最近線上運(yùn)行的一個python任務(wù)負(fù)責(zé)處理一批數(shù)據(jù),為提高處理效率,使用了python進(jìn)程池,并會打印log,本文給大家分析了Python進(jìn)程池log死鎖問題以及解決方法,需要的朋友可以參考下
    2024-01-01
  • 深入理解Python的元類

    深入理解Python的元類

    這篇文章主要為大家介紹了Python的元類,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • Django 聚合函數(shù)的具體使用

    Django 聚合函數(shù)的具體使用

    orm模型中的聚合函數(shù)跟MySQL中的聚合函數(shù)作用是一致的,也有像Sum、Avg、Count、Max、Min,接下來我們逐個介紹,下面就一起來了解一下
    2021-05-05
  • 詳解Python實(shí)現(xiàn)字典合并的四種方法

    詳解Python實(shí)現(xiàn)字典合并的四種方法

    這篇文章主要為大家詳細(xì)介紹了Python的合并字典的四種方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • PyTorch和Keras計算模型參數(shù)的例子

    PyTorch和Keras計算模型參數(shù)的例子

    今天小編就為大家分享一篇PyTorch和Keras計算模型參數(shù)的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Python中的圖形繪制簡單動畫實(shí)操

    Python中的圖形繪制簡單動畫實(shí)操

    這篇文章主要介紹了Python中的圖形繪制簡單動畫實(shí)操,?Matplotlib?是一個非常廣泛的庫,它也支持圖形動畫,動畫工具以?matplotlib.animation?基類為中心,它提供了一個框架,圍繞該框架構(gòu)建動畫,下面來看看具體的實(shí)現(xiàn)過程吧,需要的小伙伴可以參考一下
    2022-02-02
  • 基于Python實(shí)現(xiàn)的ID3決策樹功能示例

    基于Python實(shí)現(xiàn)的ID3決策樹功能示例

    這篇文章主要介紹了基于Python實(shí)現(xiàn)的ID3決策樹功能,簡單描述了ID3決策樹的相關(guān)概念,并結(jié)合實(shí)例形式分析了Python實(shí)現(xiàn)ID3決策樹的具體定義與使用技巧,需要的朋友可以參考下
    2018-01-01
  • Python3中編碼與解碼之Unicode與bytes的講解

    Python3中編碼與解碼之Unicode與bytes的講解

    今天小編就為大家分享一篇關(guān)于Python3中編碼與解碼之Unicode與bytes的講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • 詳解使用python crontab設(shè)置linux定時任務(wù)

    詳解使用python crontab設(shè)置linux定時任務(wù)

    本篇文章主要介紹了使用python crontab設(shè)置linux定時任務(wù),具有一定的參考價值,有需要的可以了解一下。
    2016-12-12

最新評論