电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:132日期:2022-06-27 11:26:41

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

前綴表達(dá)式

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

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

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

中綴表達(dá)式

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

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

后綴表達(dá)式

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

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

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

因?yàn)闊o(wú)需考慮優(yōu)先級(jí),運(yùn)算是線性結(jié)構(gòu)的,其用棧實(shí)現(xiàn)會(huì)很簡(jiǎn)單

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

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

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

具體方式

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

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

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

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

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

注意點(diǎn):

有時(shí)候’-’(負(fù)號(hào))是單目運(yùn)算符,則要修改運(yùn)算數(shù).遇到其他運(yùn)算符(如冪運(yùn)算)也類(lèi)似.

python代碼例子

’’’中綴轉(zhuǎn)換為后綴’’’a = '1+(2+6/1+2)'#a = '2+9/3-5'# 可能出現(xiàn)的符號(hào) symbol_1 = [’+’,’-’,’*’,’/’]symbol_2 = [’(’]symbol_3 = [’)’]# 符號(hào)的優(yōu)先級(jí)priority = {’#’:-1,’(’:1,’+’:2,’-’:2,’*’:3,’/’:3}match_2 = {’)’:’(’}# 存儲(chǔ)符號(hào)的棧zhan = []zhan.append('#')# 結(jié)果result = []’’’### 這里只是對(duì)表達(dá)式進(jìn)行轉(zhuǎn)換for i in a: # 如果是數(shù)字直接添加到結(jié)果 if i.isdigit(): result.append(i) # 如果是 + - * / 運(yùn)算,則先出棧更低優(yōu)先級(jí)的,然后入棧 elif i in symbol_1: # 如果優(yōu)先級(jí)低,則出棧所有優(yōu)先級(jí)>=的符號(hào) while priority[i] <= priority[zhan[-1]]: result.append(zhan.pop()) # 壓入符號(hào) zhan.append(i) # 如果是左括號(hào),直接壓入 elif i in symbol_2: zhan.append(i) # 如果是右括號(hào),則出棧,直到遇到了匹配的左括號(hào),然后吧左括號(hào)也出棧 elif i in symbol_3: while zhan[-1] != match_2[i]: result.append(zhan.pop()) zhan.pop() result.append(zhan.pop())print(’’.join(result))’’’# 下面通過(guò)將中綴表達(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 / bdef 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)換的時(shí)候就一邊進(jìn)行了運(yùn)算for i in a: # 如果是數(shù)字直接添加到結(jié)果 if i.isdigit(): result.append(i) # 如果是 + - * / 運(yùn)算,則先出棧更低優(yōu)先級(jí)的,然后入棧 elif i in symbol_1: # 如果優(yōu)先級(jí)低,則出棧所有優(yōu)先級(jí)>=的符號(hào) while priority[i] <= priority[zhan[-1]]: to_operation(result, zhan) # 壓入符號(hào) zhan.append(i) # 如果是左括號(hào),直接壓入 elif i in symbol_2: zhan.append(i) # 如果是右括號(hào),則出棧,直到遇到了匹配的左括號(hào),然后吧左括號(hào)也出棧 elif i in symbol_3: while zhan[-1] != match_2[i]: to_operation(result, zhan) zhan.pop() to_operation(result, zhan)print(result)

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 工业CT-无锡璟能智能仪器有限公司 | 青岛代理记账_青岛李沧代理记账公司_青岛崂山代理记账一个月多少钱_青岛德辉财税事务所官网 | 泰国试管婴儿_泰国第三代试管婴儿_泰国试管婴儿费用/多少钱_孕泰来 | 2025黄道吉日查询、吉时查询、老黄历查询平台- 黄道吉日查询网 | 耐高温电缆厂家-远洋高温电缆 | 常州企业采购平台_常州MRO采购公司_常州米孚机电设备有限公司 | 西安微信朋友圈广告投放_微信朋友圈推广_西安度娘网络科技有限公司 | 电动高尔夫球车|电动观光车|电动巡逻车|电动越野车厂家-绿友机械集团股份有限公司 | 爆炸冲击传感器-无线遥测传感器-航天星百科 | 新中天检测有限公司青岛分公司-山东|菏泽|济南|潍坊|泰安防雷检测验收 | 新型游乐设备,360大摆锤游乐设备「诚信厂家」-山东方鑫游乐设备 新能源汽车电池软连接,铜铝复合膜柔性连接,电力母排-容发智能科技(无锡)有限公司 | 铝板冲孔网,不锈钢冲孔网,圆孔冲孔网板,鳄鱼嘴-鱼眼防滑板,盾构走道板-江拓数控冲孔网厂-河北江拓丝网有限公司 | 超高频感应加热设备_高频感应电源厂家_CCD视觉检测设备_振动盘视觉检测设备_深圳雨滴科技-深圳市雨滴科技有限公司 | 上海办公室装修公司_办公室设计_直营办公装修-羚志悦装 | PCB接线端子_栅板式端子_线路板连接器_端子排生产厂家-置恒电气 喷码机,激光喷码打码机,鸡蛋打码机,手持打码机,自动喷码机,一物一码防伪溯源-恒欣瑞达有限公司 假肢-假肢价格-假肢厂家-河南假肢-郑州市力康假肢矫形器有限公司 | ★店家乐|服装销售管理软件|服装店收银系统|内衣店鞋店进销存软件|连锁店管理软件|收银软件手机版|会员管理系统-手机版,云版,App | 流程管理|流程管理软件|企业流程管理|微宏科技-AlphaFlow_流程管理系统软件服务商 | 齿辊分级破碎机,高低压压球机,立式双动力磨粉机-郑州长城冶金设备有限公司 | 红立方品牌应急包/急救包加盟,小成本好项目代理_应急/消防/户外用品加盟_应急好项目加盟_新奇特项目招商 - 中红方宁(北京) 供应链有限公司 | 精益专家 - 设备管理软件|HSE管理系统|设备管理系统|EHS安全管理系统 | 定量包装秤,吨袋包装称,伸缩溜管,全自动包装秤,码垛机器人,无锡市邦尧机械工程有限公司 | 苏州西朗门业-欧盟CE|莱茵UL双认证的快速卷帘门品牌厂家 | 武汉刮刮奖_刮刮卡印刷厂_为企业提供门票印刷_武汉合格证印刷_现金劵代金券印刷制作 - 武汉泽雅印刷有限公司 | 柔性输送线|柔性链板|齿形链-上海赫勒输送设备有限公司首页[输送机] | 淘剧影院_海量最新电视剧,免费高清电影随心观看 | 造价工程师网,考试时间查询,报名入口信息-网站首页 | 安规_综合测试仪,电器安全性能综合测试仪,低压母线槽安规综合测试仪-青岛合众电子有限公司 | 代理记账_公司起名核名_公司注册_工商注册-睿婕实业有限公司 | 耐磨陶瓷,耐磨陶瓷管道_厂家-淄博拓创陶瓷科技 | 骨灰存放架|骨灰盒寄存架|骨灰架厂家|智慧殡葬|公墓陵园管理系统|网上祭奠|告别厅智能化-厦门慈愿科技 | 山东锐智科电检测仪器有限公司_超声波测厚仪,涂层测厚仪,里氏硬度计,电火花检漏仪,地下管线探测仪 | 不锈钢搅拌罐_高速搅拌罐厂家-无锡市凡格德化工装备科技有限公司 | 净化车间装修_合肥厂房无尘室设计_合肥工厂洁净工程装修公司-安徽盛世和居装饰 | 土壤有机碳消解器-石油|表层油类分析采水器-青岛溯源环保设备有限公司 | 中央空调维修、中央空调保养、螺杆压缩机维修-苏州东菱空调 | 送料机_高速冲床送料机_NC伺服滚轮送料机厂家-东莞市久谐自动化设备有限公司 | LCD3D打印机|教育|桌面|光固化|FDM3D打印机|3D打印设备-广州造维科技有限公司 | 江苏南京多语种翻译-专业翻译公司报价-正规商务翻译机构-南京华彦翻译服务有限公司 | 济南电缆桥架|山东桥架-济南航丰实业有限公司 | 冷却塔改造厂家_不锈钢冷却塔_玻璃钢冷却塔改造维修-广东特菱节能空调设备有限公司 | 膏方加工_丸剂贴牌_膏滋代加工_湖北康瑞生物科技有限公司 |