本文小編為大家詳細介紹“C++怎么實現獨一無二的二叉搜索樹”,內容詳細,步驟清晰,細節處理妥當,希望這篇“C++怎么實現獨一無二的二叉搜索樹”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
成都創新互聯公司,為您提供重慶網站建設公司、重慶網站制作、網站營銷推廣、網站開發設計,對服務成都紗窗等多個行業擁有豐富的網站建設及推廣經驗。成都創新互聯公司網站建設公司成立于2013年,提供專業網站制作報價服務,我們深知市場的競爭激烈,認真對待每位客戶,為客戶提供賞心悅目的作品。 與客戶共同發展進步,是我們永遠的責任!
Given n, how many structurally unique BST"s (binary search trees) that store values 1 ... n?
Example:
Input: 3
Output: 5
Explanation:
Given n = 3, there are a total of 5 unique BST"s:
1 3 3 2 1
/ / /
3 2 1 1 3 2
/ /
2 1 2 3
這道題實際上是 卡塔蘭數 Catalan Numbe 的一個例子,如果對卡塔蘭數不熟悉的童鞋可能真不太好做。話說其實我也是今天才知道的好嘛 -.-|||,為啥我以前都不知道捏?!為啥卡塔蘭數不像斐波那契數那樣人盡皆知呢,是我太孤陋寡聞么?!不過今天知道也不晚,不斷的學習新的東西,這才是刷題的意義所在嘛! 好了,廢話不多說了,趕緊回到題目上來吧。我們先來看當 n = 1 的情況,只能形成唯一的一棵二叉搜索樹,n分別為 1,2,3 的情況如下所示:
1 n = 1
2 1 n = 2
/
1 2
1 3 3 2 1 n = 3
/ / /
3 2 1 1 3 2
/ /
2 1 2 3
就跟斐波那契數列一樣,我們把 n = 0 時賦為1,因為空樹也算一種二叉搜索樹,那么 n = 1 時的情況可以看做是其左子樹個數乘以右子樹的個數,左右子樹都是空樹,所以1乘1還是1。那么 n = 2 時,由于1和2都可以為根,分別算出來,再把它們加起來即可。n = 2 的情況可由下面式子算出(這里的 dp[i] 表示當有i個數字能組成的 BST 的個數):
dp[2] = dp[0] * dp[1] (1為根的情況,則左子樹一定不存在,右子樹可以有一個數字)
+ dp[1] * dp[0] (2為根的情況,則左子樹可以有一個數字,右子樹一定不存在)
同理可寫出 n = 3 的計算方法:
dp[3] = dp[0] * dp[2] (1為根的情況,則左子樹一定不存在,右子樹可以有兩個數字)
+ dp[1] * dp[1] (2為根的情況,則左右子樹都可以各有一個數字)
+ dp[2] * dp[0] (3為根的情況,則左子樹可以有兩個數字,右子樹一定不存在)
我們根據以上的分析,可以寫出代碼如下:
解法一:
class Solution { public: int numTrees(int n) { vector<int> dp(n + 1); dp[0] = dp[1] = 1; for (int i = 2; i <= n; ++i) { for (int j = 0; j < i; ++j) { dp[i] += dp[j] * dp[i - j - 1]; } } return dp[n]; } };
由卡特蘭數的遞推式還可以推導出其通項公式,即 C(2n,n)/(n+1),表示在 2n 個數字中任取n個數的方法再除以 n+1,只要你還沒有忘記高中的排列組合的知識,就不難寫出下面的代碼,注意在相乘的時候為了防止整型數溢出,要將結果 res 定義為長整型,參見代碼如下:
解法二:
class Solution { public: int numTrees(int n) { long res = 1; for (int i = n + 1; i <= 2 * n; ++i) { res = res * i / (i - n); } return res / (n + 1); } };
讀到這里,這篇“C++怎么實現獨一無二的二叉搜索樹”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注創新互聯行業資訊頻道。
網站名稱:C++怎么實現獨一無二的二叉搜索樹
網頁URL:http://vcdvsql.cn/article32/pphppc.html
成都網站建設公司_創新互聯,為您提供營銷型網站建設、網站排名、外貿建站、外貿網站建設、品牌網站制作、自適應網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯