訂閱
糾錯(cuò)
加入自媒體

50行代碼能做什么?教你用50行python代碼制作一個(gè)計(jì)算器

2019-01-28 14:15
python猿
關(guān)注

前言

在本篇文章中,將向大家演示咋樣像一個(gè)通用計(jì)算器一樣解析并計(jì)算一個(gè)四則運(yùn)算表達(dá)式。我們結(jié)束的時(shí)候,我們將得到一個(gè)可以處理諸如 1+2*-(-3+2)/5.6+3樣式的表達(dá)式的計(jì)算器了。當(dāng)然,你也可以將它拓展的更為強(qiáng)大。

語法

對于那些不懂的如何解析和正式語法工作的人而言,這里有一個(gè)快速的概覽:正式語法是用來解析文本的一些不同層面的規(guī)則。每一個(gè)規(guī)則都描述了相對應(yīng)的那部分輸入的文本是如何組成的。

這里是一個(gè)用來展示如何解析1+2+3+4的例子:

或者用 EBNF:

解析器每次都會(huì)尋找add+number或者number+number,找到一個(gè)之后就會(huì)將其轉(zhuǎn)換成add;旧隙裕恳粋(gè)解析器的目標(biāo)都在于盡可能的找到最高層次的表達(dá)式抽象。

以下是解析器的每個(gè)步驟:

number + number + number + number

第一次轉(zhuǎn)換將所有的Number變成“number”規(guī)則

[number + number] + number + number

解析器找到了它的第一個(gè)匹配模式!

[add + number] + number

在轉(zhuǎn)換成一個(gè)模式之后,它開始尋找下一個(gè)

[add + number]

add

這些有次序的符號變成了一個(gè)層次上的兩個(gè)簡單規(guī)則: number+number和add+number。這樣,只需要告訴計(jì)算機(jī)如果解決這兩個(gè)問題,它就能解析整個(gè)表達(dá)式。事實(shí)上,無論多長的加法序列,它都能解決! 這就是形式文法的力量。

運(yùn)算符優(yōu)先級

算數(shù)表達(dá)式并不僅僅是符號的線性增長,運(yùn)算符創(chuàng)造了一個(gè)隱式的層次結(jié)構(gòu),這非常適合用形式文法來表示:

這相當(dāng)于:

我們可以通過嵌套規(guī)則表示此語法中的結(jié)構(gòu):

讓我們在腦海中模擬一下使用這個(gè)神奇的解析器來分析1+2*3*4的過程:

number + number * number * number

number + [number * number] * number

解析器不知道number+number的結(jié)果,所以這是它(解析器)的另一個(gè)選擇

number + [mul * number]

number + mul

現(xiàn)在我們遇到了一點(diǎn)困難! 解析器不知道如何處理number+mul。我們可以區(qū)分這種情況,但是如果我們繼續(xù)探索下去,就會(huì)發(fā)現(xiàn)有很多不同的沒有考慮到得可能,比如mul+number, add+number, add+add, 等等。

那么我們應(yīng)該怎么做呢?

幸運(yùn)的是,我們可以做一點(diǎn)小“把戲”:我們可以認(rèn)為一個(gè)number本身是一個(gè)乘積,并且一個(gè)乘積本身是一個(gè)和!

這種思路一開始看起來有點(diǎn)古怪,不過它的確是有意義的:

但是如果 mul能夠變成 add, 且 number能夠變成 mul , 有些行的內(nèi)容就變得多余了。丟棄它們,我們就得到了:

讓我們來使用這種新的語法來模擬運(yùn)行一下1+2*3*4:

number + number * number * number

現(xiàn)在沒有一個(gè)規(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

成功了。。

如果你覺得這個(gè)很奇妙,那么嘗試著去用另一種算數(shù)表達(dá)式來模擬運(yùn)行一下,然后看看表達(dá)式是如何用正確的方式來一步步解決問題的。或者等著閱讀下一節(jié)中的內(nèi)容,看看計(jì)算機(jī)是如何一步步運(yùn)行出來的!

1  2  下一頁>  
聲明: 本文由入駐維科號的作者撰寫,觀點(diǎn)僅代表作者本人,不代表OFweek立場。如有侵權(quán)或其他問題,請聯(lián)系舉報(bào)。

發(fā)表評論

0條評論,0人參與

請輸入評論內(nèi)容...

請輸入評論/評論長度6~500個(gè)字

您提交的評論過于頻繁,請輸入驗(yàn)證碼繼續(xù)

  • 看不清,點(diǎn)擊換一張  刷新

暫無評論

暫無評論

人工智能 獵頭職位 更多
掃碼關(guān)注公眾號
OFweek人工智能網(wǎng)
獲取更多精彩內(nèi)容
文章糾錯(cuò)
x
*文字標(biāo)題:
*糾錯(cuò)內(nèi)容:
聯(lián)系郵箱:
*驗(yàn) 證 碼:

粵公網(wǎng)安備 44030502002758號