成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

【LintCode】Expression Expand 非遞歸stack完成DFS(String)

livem / 1658人閱讀

摘要:直接的方法不可取因為是每一層。層直接從取出實際上是將這個后應(yīng)該得到。這個時候考慮逆向,建立一個,將出來的東西再一個順序,逆逆得順是一個很好用的操作符,判斷一個對象是否是一個類的實例??有⌒囊稽c這種情況啊代碼

這道題真是超級棒的stack DFS樣板題啊,在這里給自己寫個小小的總結(jié)

思路:
想到stack并不難,這種嵌套式一般是DFS的思想,先走到最里面最小的那個括號,然后逐漸回到上一層→上一層。又∵非遞歸,“BFS queue, DFS stack”。想到用stack并不難
Stack non-recursion DFS template
要點是,處理完之后重新返回stack,才能夠回到上一層操作

這個題具體操作起來真是很多可圈可點的地方,主要是在于String的處理上

reverse
因為stack的順序,在這個題中需要每次將每層里的內(nèi)容reverse。直接StringBuilder的reverse方法不可?。阂驗槭莚everse每一層。e.g. 3[ab]2[c]層直接從stack取出實際上是cc, ababab將這個reverse后應(yīng)該得到abababcc。這個時候考慮逆向stack,建立一個stack buffer,將stack pop出來的東西再reverse一個順序,逆逆得順

instanceof
nstanceof是一個很好用的操作符,a instanceof A,判斷“一個對象是否是一個類的實例”。作為操作符instanceof不可以直接在最前面!取非(比如>=這種也是),而是用 a instanceof A == false之類的判斷

復(fù)制StringBuilder
add到底append幾次,怎么append:直接append add 是不可以的,因為add是在變的,必須要先將第一個add保存起來,類似于dummy node,預(yù)先保存queue size這種“錨定”。


小心一點0[peer], -3[aaa]這種情況啊!

代碼
public class Solution {

public String expressionExpand(String s) {
    Stack stack = new Stack<>();
    char[] arr = s.toCharArray();
    
    int num = 0;
    for(char c : arr){
       if(Character.isDigit(c)){
           num = num * 10 + c - "0";
       }
       else if(c == "["){
           stack.push(Integer.valueOf(num));
           num = 0;
       }
       else if(c == "]"){
           popStack(stack);
       }
       else{
           stack.push(c);
       }
    }
    popStack(stack);
    return stack.pop().toString();
}
private void popStack(Stack stack){
    StringBuilder add = new StringBuilder();
    int count;
    Stack buffer = new Stack();
    while(!stack.isEmpty() && stack.peek() instanceof Integer == false){
        buffer.push(stack.pop());
    }
    while(!buffer.isEmpty()){
        add.append(buffer.pop());
    }
    
    count = stack.isEmpty()? 1 : (Integer) stack.pop();
    StringBuilder part = new StringBuilder(add);
    if(count > 0){
        for(int i = 0; i < count - 1; i++)
            add.append(part);
        stack.push(add);// reput
    }
}

}

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/66920.html

相關(guān)文章

  • [LintCode] Expression Tree Build

    Problem The structure of Expression Tree is a binary tree to evaluate certain expressions.All leaves of the Expression Tree have an number string value. All non-leaves of the Expression Tree have an o...

    qpal 評論0 收藏0
  • 表達式類算法題小結(jié)

    摘要:將表達式轉(zhuǎn)換為逆波蘭式,然后求值轉(zhuǎn)換中綴表達式為逆波蘭式魯棒性檢測,表達式中沒有操作數(shù)計算逆波蘭式值參考 表達式類算法題小結(jié) [TOC] 聲明 文章均為本人技術(shù)筆記,轉(zhuǎn)載請注明出處:[1] https://segmentfault.com/u/yzwall[2] blog.csdn.net/j_dark/ 表達式分類 根據(jù)運算符與相關(guān)操作操作數(shù)的位置不同,將表達式分為前綴,中綴和后綴表...

    Heier 評論0 收藏0
  • [LintCode] Topological Sorting [BFS & DFS]

    摘要:當(dāng)隊列非空時,拿出最后放入的元素。若減后入度為,則這個結(jié)點遍歷完成,放入結(jié)果數(shù)組和隊列。遞歸函數(shù)去遍歷的,繼續(xù)在中標(biāo)記,使得所有點只遍歷一次。最深的點最先,根結(jié)點最后,加入結(jié)果數(shù)組的頭部處。 Problem Given an directed graph, a topological order of the graph nodes is defined as follow: For ...

    draveness 評論0 收藏0
  • js 中二叉樹的深度遍歷與廣度遍歷(遞歸實現(xiàn)與遞歸實現(xiàn))

    摘要:樹中結(jié)點的最大層次稱為樹的深度或高度。二叉樹有深度遍歷和廣度遍歷,深度遍歷有前序中序和后序三種遍歷方法。二叉樹的前序遍歷可以用來顯示目錄結(jié)構(gòu)等中序遍歷可以實現(xiàn)表達式樹,在編譯器底層很有用后序遍歷可以用來實現(xiàn)計算目錄內(nèi)的文件及其信息等。 樹的簡介 棧、隊列、鏈表等數(shù)據(jù)結(jié)構(gòu),都是順序數(shù)據(jù)結(jié)構(gòu)。而樹是非順序數(shù)據(jù)結(jié)構(gòu)。樹型結(jié)構(gòu)是一類非常重要的非線性結(jié)構(gòu)。直觀地,樹型結(jié)構(gòu)是以分支關(guān)系定義的層次結(jié)...

    Yuanf 評論0 收藏0
  • [LintCode] Evaluate Reverse Polish Notation

    摘要:中的運算符,運算之后要出來,繼續(xù)遍歷數(shù)組。是放入新的數(shù)字,用轉(zhuǎn)換為均可。 Problem Evaluate the value of an arithmetic expression in Reverse Polish Notation. Valid operators are +, -, *, /. Each operand may be an integer or another ...

    luckyyulin 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<