50行代碼能做什么?教你用50行python代碼制作一個計算器
前言
在本篇文章中,將向大家演示咋樣像一個通用計算器一樣解析并計算一個四則運算表達式。我們結(jié)束的時候,我們將得到一個可以處理諸如 1+2*-(-3+2)/5.6+3樣式的表達式的計算器了。當(dāng)然,你也可以將它拓展的更為強大。
語法
對于那些不懂的如何解析和正式語法工作的人而言,這里有一個快速的概覽:正式語法是用來解析文本的一些不同層面的規(guī)則。每一個規(guī)則都描述了相對應(yīng)的那部分輸入的文本是如何組成的。
這里是一個用來展示如何解析1+2+3+4的例子:
或者用 EBNF:
解析器每次都會尋找add+number或者number+number,找到一個之后就會將其轉(zhuǎn)換成add。基本上而言,每一個解析器的目標(biāo)都在于盡可能的找到最高層次的表達式抽象。
以下是解析器的每個步驟:
number + number + number + number
第一次轉(zhuǎn)換將所有的Number變成“number”規(guī)則
[number + number] + number + number
解析器找到了它的第一個匹配模式!
[add + number] + number
在轉(zhuǎn)換成一個模式之后,它開始尋找下一個
[add + number]
add
這些有次序的符號變成了一個層次上的兩個簡單規(guī)則: number+number和add+number。這樣,只需要告訴計算機如果解決這兩個問題,它就能解析整個表達式。事實上,無論多長的加法序列,它都能解決! 這就是形式文法的力量。
運算符優(yōu)先級
算數(shù)表達式并不僅僅是符號的線性增長,運算符創(chuàng)造了一個隱式的層次結(jié)構(gòu),這非常適合用形式文法來表示:
這相當(dāng)于:
我們可以通過嵌套規(guī)則表示此語法中的結(jié)構(gòu):
讓我們在腦海中模擬一下使用這個神奇的解析器來分析1+2*3*4的過程:
number + number * number * number
number + [number * number] * number
解析器不知道number+number的結(jié)果,所以這是它(解析器)的另一個選擇
number + [mul * number]
number + mul
現(xiàn)在我們遇到了一點困難! 解析器不知道如何處理number+mul。我們可以區(qū)分這種情況,但是如果我們繼續(xù)探索下去,就會發(fā)現(xiàn)有很多不同的沒有考慮到得可能,比如mul+number, add+number, add+add, 等等。
那么我們應(yīng)該怎么做呢?
幸運的是,我們可以做一點小“把戲”:我們可以認(rèn)為一個number本身是一個乘積,并且一個乘積本身是一個和!
這種思路一開始看起來有點古怪,不過它的確是有意義的:
但是如果 mul能夠變成 add, 且 number能夠變成 mul , 有些行的內(nèi)容就變得多余了。丟棄它們,我們就得到了:
讓我們來使用這種新的語法來模擬運行一下1+2*3*4:
number + number * number * number
現(xiàn)在沒有一個規(guī)則是對應(yīng)number*number的了,但是解析器可以“變得有創(chuàng)造性”
number + [number] * number * number
number + [mul * number] * number
number + [mul * number]
[number] + mul
[mul] + mul
[add + mul]
add
成功了。!
如果你覺得這個很奇妙,那么嘗試著去用另一種算數(shù)表達式來模擬運行一下,然后看看表達式是如何用正確的方式來一步步解決問題的;蛘叩戎喿x下一節(jié)中的內(nèi)容,看看計算機是如何一步步運行出來的!

請輸入評論內(nèi)容...
請輸入評論/評論長度6~500個字
最新活動更多
-
即日-9.1立即下載>> 【限時下載】ADI中國三十周年感恩回饋助力企業(yè)升級!
-
即日-9.16點擊進入 >> 【限時福利】TE 2025國際物聯(lián)網(wǎng)展·深圳站
-
10月23日立即報名>> Works With 開發(fā)者大會深圳站
-
10月24日立即參評>> 【評選】維科杯·OFweek 2025(第十屆)物聯(lián)網(wǎng)行業(yè)年度評選
-
11月27日立即報名>> 【工程師系列】汽車電子技術(shù)在線大會
-
12月18日立即報名>> 【線下會議】OFweek 2025(第十屆)物聯(lián)網(wǎng)產(chǎn)業(yè)大會
推薦專題
- 1 阿里首位程序員,“掃地僧”多隆已離職
- 2 先進算力新選擇 | 2025華為算力場景發(fā)布會暨北京xPN伙伴大會成功舉辦
- 3 宇樹機器人撞人事件的深度剖析:六維力傳感器如何成為人機安全的關(guān)鍵屏障
- 4 清華跑出具身智能獨角獸:給機器人安上眼睛和大腦,融資近20億
- 5 特朗普要求英特爾首位華人 CEO 辭職
- 6 踢館大廠和微軟,剖析WPS靈犀的AI實用主義
- 7 騰訊 Q2 財報亮眼:AI 已成第二增長曲線
- 8 谷歌吹響AI沖鋒號,AI還有哪些機會
- 9 蘋果把身家押在Siri上:一場輸不起的自我革命
- 10 共探合作新機遇!江門市新會區(qū)(深圳)“AI + 機器人” 產(chǎn)業(yè)對接會成功舉辦