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

拜托,面試別再問我表達式求值了!!!

開發 開發工具 前端
上周面試一個候選人,問了一個數據結構與算法的問題,表達式求值,本來以為是送分題,候選人竟一時語塞。 為了廣大面試的同學不再在這一題上送命,今天花幾分鐘把這個問題講透徹。

上周面試一個候選人,問了一個數據結構與算法的問題,表達式求值。

題目大概是這樣的:

輸入長度為n的字符串,例如:1+2+3*4*5

輸出表達式的值,即:63

我暗示的問:應該用什么數據結構?

候選人回答:棧。

畫外音:算是答對。

問:時間復雜度呢?

回答:O(n^2)

畫外音:額,應該不需要兩個for循環吧。

我接著提示:應該先計算哪一步?

候選人回答:先計算3*4。

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

實際應該先計算1+2,說明候選人對“表達式求值”并沒有搞透。

怎么用棧來實現呢?

候選人:…

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

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

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

[[262616]]

“表達式求值”問題,兩個核心關鍵點:

(1)雙棧,一個操作數棧,一個運算符棧;

(2)運算符優先級,棧頂運算符,和,即將入棧的運算符的優先級比較:

  • 如果棧頂的運算符優先級低,新運算符直接入棧
  • 如果棧頂的運算符優先級高,先出棧計算,新運算符再入棧

仍以1+2+3*4*5舉例,看是如何利用上述兩個關鍵點實施計算的。

首先,這個例子只有+和*兩個運算符,所以它的運算符表是:

這里的含義是:

  • 如果棧頂是+,即將入棧的是+,棧頂優先級高,需要先計算,再入棧;
  • 如果棧頂是+,即將入棧的是*,棧頂優先級低,直接入棧;
  • 如果棧頂是*,即將入棧的是+,棧頂優先級高,需要先計算,再入棧;
  • 如果棧頂是*,即將入棧的是*,棧頂優先級高,需要先計算,再入棧;

畫外音:運算符有+-*/()~^&都沒問題,如果共有n個運算符,會有一個n*n的優先級表。

有了運算符表,一切就好辦了。

一開始,初始化好輸入的字符串,以及操作數棧,運算符棧。

一步步,掃描字符串,操作數一個個入棧,運算符也入棧。

畫外音:如果有“789”這樣的多個字符的多位數,要先轉化為數字789,這個過程很容易。

下一個操作符要入棧時,需要先比較優先級。

棧內的優先級高,必須先計算,才能入棧。

計算的過程為:

  • 操作數出棧,作為num2;
  • 操作數出棧,作為num1;
  • 運算符出棧,作為op;
  • 計算出結果;
  • 結果入操作數棧;

棧內的優先級低,可以直接入棧。

字符串繼續移動。

又要比較優先級了。

棧內的優先級高,還是先計算(3*4=12),再入棧。

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

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

總結

“表達式求值”問題,兩個核心關鍵點:

(1)雙棧,一個操作數棧,一個運算符棧;

(2)運算符優先級,棧頂運算符,和,即將入棧的運算符的優先級比較:

  • 如果棧頂的運算符優先級低,新運算符直接入棧
  • 如果棧頂的運算符優先級高,先出棧計算,新運算符再入棧

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

思路比結論重要,學到了嗎?

【本文為51CTO專欄作者“58沈劍”原創稿件,轉載請聯系原作者】

戳這里,看該作者更多好文

責任編輯:趙寧寧 來源: 51CTO專欄
相關推薦

2019-01-08 15:11:50

最大值最小值算法

2018-09-28 05:25:53

TopK算法代碼

2018-11-01 13:49:23

桶排序排序面試

2018-10-28 22:37:00

計數排序排序面試

2018-11-06 11:40:19

時間復雜度面試算法

2020-04-22 11:19:07

貪心算法動態規劃

2021-01-22 10:09:23

簡歷求職者面試

2020-03-30 17:20:54

B+樹SQL索引

2020-09-02 08:04:59

多線程互聯網高并發

2022-03-14 10:14:43

底層系統Nacos

2018-11-09 09:34:05

面試Spring Clou底層

2020-04-16 08:22:11

HTTPS加解密協議

2020-12-11 09:24:19

Elasticsear存儲數據

2020-09-24 14:40:55

Python 開發編程語言

2019-08-29 09:49:50

2015-02-13 10:42:31

前端工具Dreamweaver

2023-12-13 10:12:40

Python函數lambda

2019-07-10 10:06:24

面試官三次握手四次揮手

2020-12-21 08:22:36

前綴后綴中綴

2022-11-24 06:33:43

表達式求值運算
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品久久久久久久久久久久 | 欧美乱淫视频 | 亚洲国产成人精品久久久国产成人一区 | 久久久久久久亚洲精品 | 久草在线中文888 | 91在线免费视频 | 综合欧美亚洲 | 日韩欧美在线观看视频 | 免费视频中文字幕 | 久久美女网 | 国产精品免费av | 精品久久电影 | 99精品在线 | 国产精品久久久久久52avav | 欧美日韩免费视频 | 久久精片 | 国产激情视频网址 | 亚洲精品在线免费观看视频 | 日韩在线免费视频 | 国产999在线观看 | 日韩一区在线播放 | 久久精品国产亚洲一区二区三区 | 午夜久久久久久久久久一区二区 | 亚洲第一色站 | 国际精品鲁一鲁一区二区小说 | 国产ts人妖另类 | 久久婷婷麻豆国产91天堂 | 91资源在线 | 日韩av一区二区在线观看 | 亚洲视频不卡 | 国产网站在线免费观看 | 成人国产精品久久久 | 精品在线一区二区三区 | 国产午夜精品一区二区三区四区 | 在线中文一区 | 国产91精品久久久久久久网曝门 | 免费网站国产 | 欧美精品一区二区免费 | 国产成人精品一区二 | 亚洲 欧美 另类 日韩 | 精品视频一区二区在线观看 |