摘要:假設壓入棧的所有數(shù)字均不相等。注意這兩個序列的長度是相等的思路借助一個輔助棧來存儲數(shù)據(jù)。當所有數(shù)據(jù)入棧完成,如果出棧順序正確,那么輔助棧應該為空。若存在,左右子樹,遞歸檢測左右子樹是否復合規(guī)范。
1.包含min函數(shù)的棧
定義棧的數(shù)據(jù)結構,請在該類型中實現(xiàn)一個能夠得到棧中所含最小元素的min函數(shù)(時間復雜度應為O(1))。
思路1.定義兩個棧,一個棧用于存儲數(shù)據(jù),另一個棧用于存儲每次數(shù)據(jù)進棧時棧的最小值.
2.每次數(shù)據(jù)進棧時,將此數(shù)據(jù)和最小值棧的棧頂元素比較,將二者比較的較小值再次存入最小值棧.
4.數(shù)據(jù)棧出棧,最小值棧也出棧。
3.這樣最小值棧的棧頂永遠是當前棧的最小值。
代碼var dataStack = []; var minStack = []; function push(node) { dataStack.push(node); if(minStack.length === 0 || node < min()){ minStack.push(node); }else{ minStack.push(min()); } } function pop() { minStack.pop(); return dataStack.pop(); } function top() { var length = dataStack.length; return length>0&&dataStack[length-1] } function min() { var length = minStack.length; return length>0&&minStack[length-1] }2.棧的壓入、彈出序列
輸入兩個整數(shù)序列,第一個序列表示棧的壓入順序,請判斷第二個序列是否可能為該棧的彈出順序。假設壓入棧的所有數(shù)字均不相等。例如序列1,2,3,4,5是某棧的壓入順序,序列4,5,3,2,1是該壓棧序列對應的一個彈出序列,但4,3,5,1,2就不可能是該壓棧序列的彈出序列。(注意:這兩個序列的長度是相等的)
思路1.借助一個輔助棧來存儲數(shù)據(jù)。
2.將pushV中的數(shù)據(jù)依次入棧。
3.出棧有可能在任意一次入棧后進行,當出棧數(shù)據(jù)不再位于棧頂,繼續(xù)入棧。
4.所以設置一個索引,記錄當前出棧的位置,每次出棧索引+1。
5.當所有數(shù)據(jù)入棧完成,如果出棧順序正確,那么輔助棧應該為空。
代碼function IsPopOrder(pushV, popV) { if (!pushV || !popV || pushV.length == 0 || popV.length == 0) { return; } var stack = []; var idx = 0; for (var i = 0; i < pushV.length; i++) { stack.push(pushV[i]); while (stack.length && stack[stack.length - 1] == popV[idx]) { stack.pop(); idx++; } } return stack.length == 0; }3.題二叉樹的后續(xù)遍歷
輸入一個整數(shù)數(shù)組,判斷該數(shù)組是不是某二叉搜索樹的后序遍歷的結果。如果是則輸出Yes,否則輸出No。假設輸入的數(shù)組的任意兩個數(shù)字都互不相同。
思路1.后序遍歷:分成三部分:最后一個節(jié)點為跟節(jié)點,第二部分為左子樹的值比跟節(jié)點都小,第三部分為右子樹的值比跟節(jié)點都大。
2.先檢測左子樹,左側比跟節(jié)點小的值都判定為左子樹。
3.除最后一個節(jié)點外和左子樹外的其他值為右子樹,右子樹有一個比跟節(jié)點小,則返回false。
4.若存在,左、右子樹,遞歸檢測左、右子樹是否復合規(guī)范。
代碼function VerifySquenceOfBST(sequence) { if (sequence && sequence.length > 0) { var root = sequence[sequence.length - 1] for (var i = 0; i < sequence.length - 1; i++) { if (sequence[i] > root) { break; } } for (let j = i; j < sequence.length - 1; j++) { if (sequence[j] < root) { return false; } } var left = true; if (i > 0) { left = VerifySquenceOfBST(sequence.slice(0, i)); } var right = true; if (i < sequence.length - 1) { right = VerifySquenceOfBST(sequence.slice(i, sequence.length - 1)); } return left && right; } }4.二叉樹中和為某一值的路徑
輸入一顆二叉樹的跟節(jié)點和一個整數(shù),打印出二叉樹中結點值的和為輸入整數(shù)的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(注意: 在返回值的list中,數(shù)組長度大的數(shù)組靠前)
思路1.使用前序遍歷
2.使用一個輔助棧來存儲當前路徑里的數(shù)據(jù)
3.記錄一個當前路徑的和
4.遍歷到當前節(jié)點后,當前值入路徑棧,和加當前值
5.遞歸左孩子右孩子節(jié)點
6.遍歷完一個節(jié)點,退回到上一個節(jié)點,從路徑棧中移除當前的值,和減當前值
代碼function FindPath(root, expectNumber) { var result = []; if (!root) { return result; } findPath(root, expectNumber, [], 0, result); return result; } function findPath(node, expectNumber, vector, sum, result) { vector.push(node.val); sum += node.val; var isLeaf = !node.left && !node.right; if (isLeaf && sum === expectNumber) { result.push(vector.slice(0)); } if (node.left) { findPath(node.left, expectNumber, vector, sum, result); } if (node.right) { findPath(node.right, expectNumber, vector, sum, result); } vector.pop(); }
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/101756.html
摘要:正如我標題所說,簡歷被拒。看了我簡歷之后說頭條競爭激烈,我背景不夠,點到為止。。三準備面試其實從三月份投遞簡歷開始準備面試到四月份收,也不過個月的時間,但這都是建立在我過去一年的積累啊。 本文是 無精瘋 同學投稿的面試經歷 關注微信公眾號:進擊的java程序員K,即可獲取最新BAT面試資料一份 在此感謝 無精瘋 同學的分享 目錄: 印象中的頭條 面試背景 準備面試 ...
摘要:正如我標題所說,簡歷被拒??戳宋液啔v之后說頭條競爭激烈,我背景不夠,點到為止。。三準備面試其實從三月份投遞簡歷開始準備面試到四月份收,也不過個月的時間,但這都是建立在我過去一年的積累啊。 本文是 無精瘋 同學投稿的面試經歷 關注微信公眾號:進擊的java程序員K,即可獲取最新BAT面試資料一份 在此感謝 無精瘋 同學的分享目錄:印象中的頭條面試背景準備面試頭條一面(Java+項目)頭條...
摘要:圖解第二種算法圖解代碼示例算法如果為真,說明拿到的是二進制序列的個數(shù)為算法為的時候說明已經拿完了,循環(huán)終止二進制序列中的個數(shù)以上代碼,還可做優(yōu)化在此僅作參考,若有更好的算法,還望能夠私信告知,多謝各位。 ?前言?: 算法是一個程序員的內功,能很好的體現(xiàn)程序員的編程思維,通過學習和掌握常見的算...
摘要:拆分鏈表,將和進行拆分,保證原始鏈表不受影響。要求不能創(chuàng)建任何新的結點,只能調整樹中結點指針的指向。輸入一個字符串長度不超過可能有字符重復字符只包括大小寫字母。遞歸,記錄一個當前節(jié)點的位置,該位置指向最后一個節(jié)點時記錄一次排列。 1.復雜鏈表的復制 輸入一個復雜鏈表(每個節(jié)點中有節(jié)點值,以及兩個指針,一個指向下一個節(jié)點,另一個特殊指針指向任意一個節(jié)點),返回結果為復制后復雜鏈表的hea...
閱讀 1892·2021-09-24 09:48
閱讀 3236·2021-08-26 14:14
閱讀 1692·2021-08-20 09:36
閱讀 1480·2019-08-30 15:55
閱讀 3642·2019-08-26 17:15
閱讀 1438·2019-08-26 12:09
閱讀 618·2019-08-26 11:59
閱讀 3336·2019-08-26 11:57