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

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

精選
開發
“表達式求值”問題,兩個核心關鍵點:雙棧,一個操作數棧,一個運算符棧;運算符優先級,棧頂運算符,和,即將入棧的運算符的優先級比較。

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

題目大概是這樣的:

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

我暗示的問:應該用什么數據結構?候選人回答:棧。

畫外音:算是答對。?

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

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

我接著提示:應該先計算哪一步?候選人回答:先計算3*4。

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

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

怎么用棧來實現呢?候選人:…

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

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

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

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

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

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

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

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

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

圖片

這里的含義是:

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

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

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

圖片

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

圖片

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

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

圖片

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

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

圖片

計算的過程為:

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

圖片

(5) 結果入操作數棧;

圖片

接下來,運算符和操作數才能繼續入棧。下一個操作符要入棧時,繼續比較與棧頂的優先級。

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

圖片

字符串繼續移動。

圖片

又要比較優先級了。

圖片

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

圖片

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

圖片

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

總結?

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

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

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

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

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

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

責任編輯:趙寧寧 來源: 架構師之路
相關推薦

2019-04-16 13:30:05

表達式求值數據結構算法

2011-04-28 15:53:03

Android MarAndroid

2013-12-02 09:49:15

微軟CEO貝茨硅谷

2011-03-17 16:54:38

AMDCEO

2009-02-17 14:44:40

360安全衛士周鴻祎IT

2014-12-15 15:28:46

時代馬云庫克

2021-06-10 10:07:27

網絡釣魚攻擊網絡安全

2022-09-22 18:31:24

Kafka

2023-12-13 10:12:40

Python函數lambda

2020-12-21 08:22:36

前綴后綴中綴

2013-11-06 15:56:13

微軟CEO鮑爾默

2013-11-15 09:44:37

微軟CEO

2013-11-15 11:20:55

微軟微軟CEO微軟COO

2019-06-10 10:29:23

Java面試技巧

2018-12-17 08:14:49

互聯網Java Kafka

2024-11-29 08:11:27

2017-12-09 22:09:05

編程KotlinC語言

2011-07-15 10:34:16

aviatorJava

2024-01-17 07:00:56

JIT 技術數據庫表達式求值

2020-12-18 09:05:13

算法單調棧
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久一区二区av | 熟女毛片 | 九色在线 | 日韩精品激情 | 日韩欧美国产成人一区二区 | 欧美一级二级三级 | 亚洲国产成人精品女人久久久 | 国产免费一区二区 | 国产欧美精品一区二区三区 | 夜夜爽99久久国产综合精品女不卡 | 久在线视频 | 成人免费在线视频 | 国产精品久久久久久久久久了 | 欧美一二三四成人免费视频 | 伦理一区二区 | 欧美在线综合 | 成人在线视频免费播放 | 男人天堂色 | 亚洲 自拍 另类 欧美 丝袜 | 久久成人免费 | 日韩精品成人 | 日本一区二区电影 | 国产激情综合五月久久 | 亚洲成人一区二区 | 91看片网| 亚洲成人av| 久久在视频 | 午夜网 | 久久久久久国产精品 | 婷婷激情综合 | 亚洲欧美综合精品久久成人 | 在线a视频| 欧美视频精品 | 国产精品一区二区三区四区五区 | 欧美日韩不卡在线 | 天天干视频| 日日操网站 | 国产在线不卡 | 亚洲国产精品第一区二区 | 在线视频 中文字幕 | 中文字幕 欧美 日韩 |