重建二叉樹 (劍指offer第六題)
題目:輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列{1,2,4,7,3,5,6,8}和中序遍歷序列{4,7,2,1,5,3,8,6},則重建二叉樹並返回。
有思路,但是沒寫出來。還得多練練。
解釋一下大神的幾個關鍵點:
建立左子樹時:startPre+i-startIn
其中i-startIn表示的是有幾個左孩子。
建立右子樹時:i-startIn+startPre+1
其中i-startIn同上。+1代表的是根。前序遍歷去掉左孩子和根就是右孩子開始算的地方。
大神的思路簡潔。這個程式碼風格值得學習。加油。
最後還有個問題,留著以後解決: TreeNode root=new TreeNode(pre[startPre]);
搞不懂為什麼這句會在eclipse中報錯,但在牛客測試中沒報錯。
相關推薦
重建二叉樹 (劍指offer第六題)
題目:輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列{1,2,4,7,3,5,6,8}和中序遍歷序列{4,7,2,1,5,3,8,6},則重建二叉樹並返回。 有思路,但是沒寫出來。還得多練練。 解釋一下大神的幾個關鍵
C++ 前序遍歷和中序遍歷重構二叉樹(劍指offer)
題目描述 輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列{1,2,4,7,3,5,6,8}和中序遍歷序列{4,7,2,1,5,3,8,6},則重建二叉樹並返回。 這道題之前做過幾次,以前
對稱的二叉樹(劍指offer+鏡面對稱+遞迴)
對稱的二叉樹 參與人數:904時間限制:1秒空間限制:32768K通過比例:28.19%最佳記錄:0 ms|8552K 題目描述 請實現一個函式,用來判斷一顆二叉樹是不是對稱的。注意,如果
棧的壓入 彈出序列(劍指offer第21題)
一、題目描述 輸入兩個整數序列,第一個序列表示棧的壓入順序,請判斷第二個序列是否可能為該棧的彈出順序。 假設壓入棧的所有數字均不相等。例如序列1,2,3,4,5是某棧的壓入順序,序列4,5,3,2,1是該壓棧序列對應的一個彈出序列, 但4,3,5,1,2就不可能是該壓棧序列的彈出序列。(注意:這
陣列中出現次數超過一半的數字(劍指offer第29題)
一、題目描述 陣列中有一個數字出現的次數超過陣列長度的一半,請找出這個數字。 例如輸入一個長度為9的陣列{1,2,3,2,2,2,5,4,2}。由於數字2在陣列中出現了5次, 超過陣列長度的一半,因此輸出2。如果不存在則輸出0 二、解題思路 (方法一):自己想出來的,時
用兩個棧實現佇列 (劍指offer第7題)
用兩個棧來實現一個佇列,完成佇列的Push和Pop操作。 佇列中的元素為int型別。 棧的特點:先進後出 佇列的特點:先進先出 push很好實現。 pop可能有一點難度。最開始兩個棧中都沒有元素,所有進佇列的元素都存在stack1中。因為棧是先進後出,所有最先進來的要最後出,和佇列相反。所以需要藉助s
用兩個棧實現隊列 (劍指offer第7題)
info 一個 .com 所有 有一點 bsp 都沒有 我想 完成 用兩個棧來實現一個隊列,完成隊列的Push和Pop操作。 隊列中的元素為int類型。 棧的特點:先進後出 隊列的特點:先進先出 push很好實現。 pop可能有一點難度。最開始兩個棧中都沒有元素,所有進隊列
【劍指offer第六題】旋轉陣列的最小數
題目描述 把一個數組最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。 輸入一個非減排序的陣列的一個旋轉,輸出旋轉陣列的最小元素。 例如陣列{3,4,5,1,2}為{1,2,3,4,5}的一個旋
劍指offer第六題陣列旋轉
寫在前面,1.這是我目前遇到最有趣的題目涵蓋多種思路,多種解法,也是多種問題。故記錄下來總結一下。半夜看到這道題,首先想到的是二分,後來一看最小,那不是直接遍歷就行,但是T=O(n)。2.左神的課程中提到過,對於二分搜尋,一般大家都是mid=(left+right)/2,其實
劍指offer第六題【旋轉陣列的最小數字】c++實現
題目描述 把一個數組最開始的若干個元素搬到陣列的末尾,我們稱之為陣列的旋轉。輸入一個非遞減序列的一個旋轉,輸出旋轉陣列的最小元素。例如陣列{3,4,5,1,2}為{1,2,3,4,5}的一個旋轉,該陣列的最小值為1。 本題給的也算是有序數列,一看就應該和二分沾邊,事實也是這樣。 題目給的是非遞減序列,就是
【劍指offer】重建二叉樹(含測試函式)
根據前序遍歷和中序遍歷,利用遞迴的思想實現重建二叉樹,並輸出後序遍歷 程式碼如下: /** * Created by Administrator on 2018/11/28. */ class TreeNode{//建立類 int val; TreeNode left
劍指offer面試題7:重建二叉樹(java實現)
題目:輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建該二叉樹,假設輸入的前序遍歷和中序遍歷的結果都不含重複的數字。例如:輸入前序遍歷序列{1,2,4,7,3,5,6,8}和中序遍歷序列{4,7,2,1,5,3,8,6}則重建二叉樹:其中二叉樹的定義如下: * publi
劍指offer面試題7:重建二叉樹(Java實現)
題目:輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列{1,2,4,7,3,5,6,8}和中序遍歷序列{4,7,2,1,5,3,8,6},則重建二叉樹並返回。 思路:可以把二叉樹分為左右子樹分別構建,前序
劍指offer第24題(二叉樹中和為某一值的路徑)
題目:輸入一顆二叉樹和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。 思想:由於本題中的根要在前面,因而我們首先想到的是前序遍歷。當用前序遍歷的方式訪問某一節點時,我們把該節點新增到路徑上,並累加
劍指offer 第4題 重建二叉樹
描述: 輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列{1,2,4,7,3,5,6,8}和中序遍歷序列{4,7,2,1,5,3,8,6},則重建二叉樹並返回。 思路: 遞迴,basecase為如果pre
七:重建二叉樹(依據先序遍歷(或者後序遍歷)和中序遍歷重建二叉樹)
off 相同 tree int roo 節點 先序 throw -a 對於一顆二叉樹。能夠依據先序遍歷(或者後序遍歷)和中序遍歷(樹中不含反復的數字)又一次還原出二叉樹。 解析: 1. 先序遍歷序列的第一個元素必然是根節點,能夠由此獲取二叉樹的根節點。 2. 依
重建二叉樹(四)
binary 例如 bin eno struct const 第一個 ont == 輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重復的數字。例如輸入前序遍歷序列{1,2,4,7,3,5,6,8}和中序遍歷序列{4,7,
已知前序中序重建二叉樹(未完)
#include<iostream> #include<malloc.h> using namespace std; struct node{ struct node *right,*left; int e; }; const int maxn=30; int p
重建二叉樹(JS實現)
題目 輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列{1,2,4,7,3,5,6,8}和中序遍歷序列{4,7,2,1,5,3,8,6},則重建二叉樹並返回。 /* fu
由前序遍歷和中序遍歷重建二叉樹(前序序列:1 2 3 4 5 6
由前序遍歷和中序遍歷重建二叉樹 前序序列(根-左-右):1 2 3 4 5 6 中序序列(左-根-右):3 2 4 1 6 5 1、由前序遍歷可知根節點為第一個元素1,在中序遍歷序列中找到1對