成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

表達(dá)式求值,有些候選人總以為自己懂了!

精選
開發(fā)
“表達(dá)式求值”問題,兩個(gè)核心關(guān)鍵點(diǎn):雙棧,一個(gè)操作數(shù)棧,一個(gè)運(yùn)算符棧;運(yùn)算符優(yōu)先級(jí),棧頂運(yùn)算符,和,即將入棧的運(yùn)算符的優(yōu)先級(jí)比較。

上周面試一個(gè)候選人,問了一個(gè)數(shù)據(jù)結(jié)構(gòu)與算法的問題,表達(dá)式求值。

題目大概是這樣的:

  • 輸入長(zhǎng)度為n的字符串,例如:1+2+3*4*5
  • 輸出表達(dá)式的值,即:63

我暗示的問:應(yīng)該用什么數(shù)據(jù)結(jié)構(gòu)?候選人回答:棧。

畫外音:算是答對(duì)。?

問:時(shí)間復(fù)雜度呢?回答:O(n^2)

畫外音:額,應(yīng)該不需要兩個(gè)for循環(huán)吧。?

我接著提示:應(yīng)該先計(jì)算哪一步?候選人回答:先計(jì)算3*4。

畫外音:額,難道是乘除大于加減?

實(shí)際應(yīng)該先計(jì)算1+2,說明候選人對(duì)“表達(dá)式求值”并沒有搞透。?

怎么用棧來實(shí)現(xiàn)呢?候選人:…

本來以為是送分題,候選人竟一時(shí)語塞。

為了廣大面試的同學(xué)不再在這一題上送命,今天花幾分鐘把這個(gè)問題講透徹。

畫外音:希望沒有幫面試官增加題庫。?

“表達(dá)式求值”問題,兩個(gè)核心關(guān)鍵點(diǎn):

(1) 雙棧,一個(gè)操作數(shù)棧,一個(gè)運(yùn)算符棧;

(2) 運(yùn)算符優(yōu)先級(jí),棧頂運(yùn)算符,和,即將入棧的運(yùn)算符的優(yōu)先級(jí)比較:

  • 如果棧頂?shù)倪\(yùn)算符優(yōu)先級(jí)低,新運(yùn)算符直接入棧?
  • 如果棧頂?shù)倪\(yùn)算符優(yōu)先級(jí)高,先出棧計(jì)算,新運(yùn)算符再入棧?

仍以1+2+3*4*5舉例,看是如何利用上述兩個(gè)關(guān)鍵點(diǎn)實(shí)施計(jì)算的。

首先,這個(gè)例子只有+和*兩個(gè)運(yùn)算符,所以它的運(yùn)算符表是:

圖片

這里的含義是:

  • 如果棧頂是+,即將入棧的是+,棧頂優(yōu)先級(jí)高,需要先計(jì)算,再入棧;
  • 如果棧頂是+,即將入棧的是*,棧頂優(yōu)先級(jí)低,直接入棧;
  • 如果棧頂是*,即將入棧的是+,棧頂優(yōu)先級(jí)高,需要先計(jì)算,再入棧;
  • 如果棧頂是*,即將入棧的是*,棧頂優(yōu)先級(jí)高,需要先計(jì)算,再入棧;

畫外音:運(yùn)算符有+-*/()~^&都沒問題,如果共有n個(gè)運(yùn)算符,會(huì)有一個(gè)n*n的優(yōu)先級(jí)表。?

有了運(yùn)算符表,一切就好辦了。

圖片

一開始,初始化好輸入的字符串,以及操作數(shù)棧,運(yùn)算符棧。

圖片

一步步,掃描字符串,操作數(shù)一個(gè)個(gè)入棧,運(yùn)算符也入棧。

畫外音:如果有“789”這樣的多個(gè)字符的多位數(shù),要先轉(zhuǎn)化為數(shù)字789,這個(gè)過程很容易。?

圖片

下一個(gè)操作符要入棧時(shí),需要先比較優(yōu)先級(jí)。

棧內(nèi)的優(yōu)先級(jí)高,必須先計(jì)算,才能入棧。

圖片

計(jì)算的過程為:

  • 操作數(shù)出棧,作為num2;
  • 操作數(shù)出棧,作為num1;
  • 運(yùn)算符出棧,作為op;
  • 計(jì)算出結(jié)果;

圖片

(5) 結(jié)果入操作數(shù)棧;

圖片

接下來,運(yùn)算符和操作數(shù)才能繼續(xù)入棧。下一個(gè)操作符要入棧時(shí),繼續(xù)比較與棧頂?shù)膬?yōu)先級(jí)。

棧內(nèi)的優(yōu)先級(jí)低,可以直接入棧。

圖片

字符串繼續(xù)移動(dòng)。

圖片

又要比較優(yōu)先級(jí)了。

圖片

棧內(nèi)的優(yōu)先級(jí)高,還是先計(jì)算(3*4=12),再入棧。

圖片

不斷入棧,直到字符串掃描完畢。

圖片

不斷出棧,直到得到最終結(jié)果3+60=63,算法完成。

總結(jié)?

“表達(dá)式求值”問題,兩個(gè)核心關(guān)鍵點(diǎn):

(1) 雙棧,一個(gè)操作數(shù)棧,一個(gè)運(yùn)算符棧;

(2) 運(yùn)算符優(yōu)先級(jí),棧頂運(yùn)算符,和,即將入棧的運(yùn)算符的優(yōu)先級(jí)比較:

  • 如果棧頂?shù)倪\(yùn)算符優(yōu)先級(jí)低,新運(yùn)算符直接入棧?
  • 如果棧頂?shù)倪\(yùn)算符優(yōu)先級(jí)高,先出棧計(jì)算,新運(yùn)算符再入棧?

這個(gè)方法的時(shí)間復(fù)雜度為O(n),整個(gè)字符串只需要掃描一遍。

思路比結(jié)論重要,學(xué)到了嗎??

責(zé)任編輯:趙寧寧 來源: 架構(gòu)師之路
相關(guān)推薦

2019-04-16 13:30:05

表達(dá)式求值數(shù)據(jù)結(jié)構(gòu)算法

2011-04-28 15:53:03

Android MarAndroid

2013-12-02 09:49:15

微軟CEO貝茨硅谷

2011-03-17 16:54:38

AMDCEO

2014-12-15 15:28:46

時(shí)代馬云庫克

2023-12-13 10:12:40

Python函數(shù)lambda

2009-02-17 14:44:40

360安全衛(wèi)士周鴻祎IT

2013-11-06 15:56:13

微軟CEO鮑爾默

2021-06-10 10:07:27

網(wǎng)絡(luò)釣魚攻擊網(wǎng)絡(luò)安全

2022-09-22 18:31:24

Kafka

2020-12-21 08:22:36

前綴后綴中綴

2013-11-15 11:20:55

微軟微軟CEO微軟COO

2013-11-15 09:44:37

微軟CEO

2018-12-17 08:14:49

互聯(lián)網(wǎng)Java Kafka

2019-06-10 10:29:23

Java面試技巧

2024-11-29 08:11:27

2020-12-18 09:05:13

算法單調(diào)棧

2017-12-09 22:09:05

編程KotlinC語言

2014-01-05 17:41:09

PostgreSQL表達(dá)式

2009-03-12 10:18:24

程序員80后求職
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 一区二区三区四区免费在线观看 | 91高清免费| 日韩精品久久一区二区三区 | 99在线免费观看视频 | 亚洲激情在线观看 | 亚洲精品1区| 欧美日韩精品影院 | 亚洲性人人天天夜夜摸 | 自拍中文字幕 | 免费看黄色国产 | 日本啊v在线 | 日韩精品一区二区三区视频播放 | 视频在线观看一区 | 尤物在线精品视频 | 亚洲九九 | 操久久| 91社区在线观看高清 | 亚洲精品电影在线观看 | 亚洲一区视频在线 | 国产yw851.c免费观看网站 | 国产免国产免费 | 久久久久综合 | 亚洲精品乱码 | 在线 丝袜 欧美 日韩 制服 | 亚洲精品在线视频 | 狠狠爱免费视频 | 91文字幕巨乱亚洲香蕉 | 粉嫩粉嫩芽的虎白女18在线视频 | 亚洲精品视频观看 | 成人精品| 三级欧美| 久久精品青青大伊人av | 日韩视频中文字幕 | www.天天干.com | 午夜影视免费片在线观看 | 精品国产欧美日韩不卡在线观看 | 国产精品免费观看 | 中文字幕a√| 成人一级片在线观看 | 在线观看精品视频网站 | 一区二区三区中文字幕 |