Javascript數(shù)據(jù)結(jié)構(gòu)之棧

作者原文:http://hawkzz.com/blog/blog/1515054561771

定義

棧是一種特殊的列表请唱,棧內(nèi)的元素只能通過列表的一端訪問逢渔,這一端稱為棧頂凳兵。棧被稱為一種先入后出的數(shù)據(jù)結(jié)構(gòu)宋列;

由于棧具有先入后出房揭,后入先出的特點(diǎn),所以在任何不在棧頂?shù)脑囟紵o法訪問氯葬,為了得到棧底的元素挡篓,必須先拿掉上面的元素婉陷。對(duì)棧的兩種主要操作是一個(gè)元素壓入棧和將一個(gè)元素彈出棧帚称;

原理

stack.png

棧的實(shí)現(xiàn)

1、創(chuàng)建Stack構(gòu)造函數(shù):

function Stack() {
    this.dataList = [];
    this.top = 0;
    this.length = length;
    this.push = push;
    this.pop = pop;
    this.peek = peek;
    this.clear = clear;
}

2秽澳、當(dāng)前Stack的長度

function length() {
    return this.top;
}

3闯睹、將元素壓入棧

function push(ele) {
    this.top += 1;
    this.dataList[this.top - 1] = ele;
}

4、將棧頂元素彈出棧

function pop() {
    this.top -= 1;
    return this.dataList[this.top];
}

5担神、讀取棧頂元素

function peek() {
    return this.dataList[this.top - 1];
}

6楼吃、 清空棧頂

function clear() {
    this.top = 0;
}

實(shí)現(xiàn)中綴表達(dá)式變成后綴表達(dá)式

1、規(guī)則

中綴表達(dá)式(8+3)(9-2)/(6+1)妄讯,轉(zhuǎn)換成后綴表達(dá)式83+92-61+/;

轉(zhuǎn)換過程:

  • 如果遇到操作數(shù)孩锡,直接輸出;
  • 如果遇到操作符亥贸,將其當(dāng)壓入到棧躬窜,包括左括號(hào);
  • 如果遇到右括號(hào)炕置,則將棧頂元素彈出并輸出荣挨,一直遇到到左括號(hào)為止;彈出左括號(hào)朴摊;
  • 如果遇到其他操作符默垄,從棧中彈出元素直到遇到更低優(yōu)先級(jí)元素為止,彈出后甚纲,將操作符壓入到棧口锭;
  • 當(dāng)讀到末尾時(shí),將棧里的元素依次彈出介杆;

2讹弯、實(shí)現(xiàn)

  • 首先,遇到括號(hào)直接壓入棧这溅;

  • 讀到數(shù)字8组民,直接輸出;

  • 讀到操作符" + ",直接壓入棧悲靴;

  • 讀到數(shù)字3臭胜,直接輸出莫其;

    stack棧: ( +

    輸出: 8 3

  • 讀到“)”,彈出并輸出“+”,彈出 “(”耸三;

    stack棧:

    輸出:8 3 +

  • 讀到操作符“*”乱陡,由于棧是空的,直接壓入棧仪壮;

  • 讀到“(”,直接壓入棧憨颠;

  • 讀到數(shù)字9,直接輸出积锅;

  • 讀到“-”爽彤,由于棧頂是“(”,所以直接壓入棧缚陷;

  • 讀到數(shù)字2适篙,直接輸出;

    stack棧:* ( -

    輸出:8 3 + 9 2

  • 讀到“)”,彈出并輸入“-”箫爷,彈出“(”嚷节;

    stack棧:*

    輸出:8 3 + 9 2 -

  • 讀到“/”,由于棧頂元素“*”與讀到的“/”優(yōu)先級(jí)是一樣的虎锚,所以也要彈出并輸出硫痰,然后將讀到的“/”壓入棧中;

    stack棧:/

    輸出:8 3 + 9 2 - *

  • 讀到“(”,直接壓入棧窜护;

  • 讀到數(shù)字6效斑,直接輸出;

  • 讀到操作符“+”柄慰,由于棧頂是“(”鳍悠,所以直接壓入棧;

  • 讀到數(shù)字1坐搔,直接輸出藏研;

    stack棧: / ( +

    輸出: 8 3 + 9 2 - 6 1

  • 讀到“)”,彈出并輸出“+”唆涝,彈出“(”

    stack棧: /

    輸出: 8 3 + 9 2 - 6 1 +

  • 最后叶摄,由于已經(jīng)讀完這個(gè)算術(shù)表達(dá)式皇拣,所以將棧中的元素依次彈出并輸出

    stack棧:
    輸出 8 3 + 9 2 - 6 1 + /

代碼

function init(str) { 
    var operatorStack = new Stack();
    var pushArr = [];
    for (var i = 0; i < str.length; i++) {
        if (isOperator(str[i])) {
            var topEle = operatorStack.peek();
            if (!topEle) {
                operatorStack.push(str[i]);
            } else {
                switch (str[i]) {
                    case '(':
                        operatorStack.push(str[i]);
                        break;
                    case ')':
                        while (topEle !== '(') {
                            var operator = operatorStack.pop();
                            pushArr.push(operator);
                            topEle = operatorStack.peek();
                        }
                        operatorStack.pop();
                        break;
                    case '+':
                    case '-':
                        var flag = true;
                        while (flag) {
                            if (topEle === '(') {
                                operatorStack.push(str[i]);
                                flag = false;
                            } else {
                                var operator = operatorStack.pop();
                                pushArr.push(operator);
                                topEle = operatorStack.peek();
                            }
                        }
                        break;
                    case '*':
                    case '/':
                        if (topEle === '*' || topEle === '/') {
                            var operator = operatorStack.pop();
                            pushArr.push(operator);
                        }
                        operatorStack.push(str[i]);
                        break;
                }
            }
        } else {
            pushArr.push(str[i]);
        }
    }

    if (operatorStack.length() > 0) {
        while (operatorStack.length() > 0) {
            var operator = operatorStack.pop();
            pushArr.push(operator);
        }
    }

    return pushArr.join('');
}

function isOperator(str) {
    return ['+', '-', '*', '/', '(', ')'].indexOf(str) > -1;
}

參考:http://blog.csdn.net/sgbfblog/article/details/8001651

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末粘茄,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子交排,更是在濱河造成了極大的恐慌盛撑,老刑警劉巖植阴,帶你破解...
    沈念sama閱讀 211,948評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件涧卵,死亡現(xiàn)場(chǎng)離奇詭異勤家,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)柳恐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,371評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門伐脖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來热幔,“玉大人,你說我怎么就攤上這事讼庇∫锞蓿” “怎么了?”我有些...
    開封第一講書人閱讀 157,490評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵蠕啄,是天一觀的道長场勤。 經(jīng)常有香客問我,道長歼跟,這世上最難降的妖魔是什么和媳? 我笑而不...
    開封第一講書人閱讀 56,521評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮嘹承,結(jié)果婚禮上窗价,老公的妹妹穿的比我還像新娘如庭。我一直安慰自己叹卷,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,627評(píng)論 6 386
  • 文/花漫 我一把揭開白布坪它。 她就那樣靜靜地躺著骤竹,像睡著了一般。 火紅的嫁衣襯著肌膚如雪往毡。 梳的紋絲不亂的頭發(fā)上蒙揣,一...
    開封第一講書人閱讀 49,842評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音开瞭,去河邊找鬼懒震。 笑死,一個(gè)胖子當(dāng)著我的面吹牛嗤详,可吹牛的內(nèi)容都是我干的个扰。 我是一名探鬼主播,決...
    沈念sama閱讀 38,997評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼葱色,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼递宅!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起苍狰,我...
    開封第一講書人閱讀 37,741評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤办龄,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后淋昭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體俐填,經(jīng)...
    沈念sama閱讀 44,203評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,534評(píng)論 2 327
  • 正文 我和宋清朗相戀三年翔忽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了英融。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赫段。...
    茶點(diǎn)故事閱讀 38,673評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖矢赁,靈堂內(nèi)的尸體忽然破棺而出糯笙,到底是詐尸還是另有隱情,我是刑警寧澤撩银,帶...
    沈念sama閱讀 34,339評(píng)論 4 330
  • 正文 年R本政府宣布给涕,位于F島的核電站,受9級(jí)特大地震影響额获,放射性物質(zhì)發(fā)生泄漏够庙。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,955評(píng)論 3 313
  • 文/蒙蒙 一抄邀、第九天 我趴在偏房一處隱蔽的房頂上張望耘眨。 院中可真熱鬧,春花似錦境肾、人聲如沸剔难。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,770評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽偶宫。三九已至,卻和暖如春环鲤,著一層夾襖步出監(jiān)牢的瞬間纯趋,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,000評(píng)論 1 266
  • 我被黑心中介騙來泰國打工冷离, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留吵冒,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,394評(píng)論 2 360
  • 正文 我出身青樓西剥,卻偏偏與公主長得像痹栖,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子蔫耽,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,562評(píng)論 2 349