-
題目連結
-
解題思路
-
暴力怎麼做?n個節點,我們要先選頭節點i,頭節點選中之後,左子樹的節點數就決定了,右子樹的節點數也就決定了,所以選擇頭節點i後,不同的數目是
左子樹不同數目
*右子樹不同數目
,這又是子問題了,又可以遞迴得到結果。- 有一個細節,假設n等於5,1,2,3,4,5,假設現在選擇了3為頭節點,右子樹不同數目有多少個?其實右子樹我並不用傳入4,5這兩個引數,我直接傳入2,代表的是右子樹有兩個節點,一共有多少種不同的數目。
-
遞迴只有一個引數,直接加快取就可以了
-
-
程式碼
class Solution { public: // 一共有n個節點,一共有多少種不同的搜尋二叉樹? int process(int n, vector<int> &dp) { if (n <= 1) { // 只有一個節點,或者沒有節點了 只有一種樹 return 1; } if (dp[n] != -1) { return dp[n]; } int ans = 0; // 誰做頭? for (int i = 1; i <= n; ++i) { ans += process(i - 1, dp) * process(n - i, dp); } dp[n] = ans; return ans; } int numTrees(int n) { vector<int> dp(n + 1, -1); return process(n, dp); } };
96. 不同的二叉搜尋樹
相關文章
- LeetCode 熱題 HOT 100 Java題解——96. 不同的二叉搜尋樹LeetCodeJava
- Day 36 | 62.不同路徑 、 63. 不同路徑 II 、343. 整數拆分、96.不同的二叉搜尋樹
- [Python手撕]不同的二叉搜尋樹Python
- (40/60)整數拆分、不同的二叉搜尋樹
- 二叉搜尋樹
- [leetCode]95. 不同的二叉搜尋樹 IILeetCode
- LeetCode-096-不同的二叉搜尋樹LeetCode
- LeetCode-095-不同的二叉搜尋樹 IILeetCode
- 二叉搜尋樹的操作集
- 二叉搜尋樹的結構
- Day20 | 654.最大二叉樹 、 617.合併二叉樹 、 700.二叉搜尋樹中的搜尋 98.驗證二叉搜尋樹二叉樹
- 二叉搜尋樹和二叉樹的最近公共祖先二叉樹
- <動態規劃>Leetcode96.不同的二叉搜尋樹動態規劃LeetCode
- 資料結構中的樹(二叉樹、二叉搜尋樹、AVL樹)資料結構二叉樹
- javascript實現二叉搜尋樹JavaScript
- 有序表和搜尋二叉樹二叉樹
- js實現完全排序二叉樹、二叉搜尋樹JS排序二叉樹
- 二叉搜尋樹的python實現Python
- Leetcode 700. 二叉搜尋樹中的搜尋(DAY 2)LeetCode
- JavaScript 二叉搜尋樹以及實現翻轉二叉樹JavaScript二叉樹
- 演算法篇 - 二叉搜尋樹演算法
- 資料結構-二叉搜尋樹資料結構
- 【資料結構】二叉搜尋樹!!!資料結構
- 二叉搜尋樹程式碼例項
- leetcode 700. 二叉搜尋樹中的搜尋 思考分析LeetCode
- 程式碼隨想錄day18 || 530 二叉搜尋樹最小差,501 二叉搜尋樹眾數,236 二叉搜尋樹最近公共祖先
- 6-12 二叉搜尋樹的操作集
- 程式碼隨想錄 第20天 20的總結沒看 | 654.最大二叉樹 ● 617.合併二叉樹 ● 700.二叉搜尋樹中的搜尋 ● 98.驗證二叉搜尋樹二叉樹
- 滿二叉樹、完全二叉樹、平衡二叉樹、二叉搜尋樹(二叉查詢樹)和最優二叉樹二叉樹
- 資料結構之「二叉搜尋樹」資料結構
- 一文搞定二叉排序(搜尋)樹排序
- 資料結構☞二叉搜尋樹BST資料結構
- 程式碼隨想錄演算法訓練營第第20天 | 654.最大二叉樹 、617.合併二叉樹 、700.二叉搜尋樹中的搜尋、98.驗證二叉搜尋樹演算法二叉樹
- 資料結構-二叉搜尋樹的實現資料結構
- Java實現二叉搜尋樹的插入、刪除Java
- 二叉樹的插入和搜尋–python實現二叉樹Python
- 701. 二叉搜尋樹中的插入操作
- Leedcode-二叉搜尋樹中的眾數