您好,登錄后才能下訂單哦!
小編給大家分享一下C++中二叉樹直徑與合并的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
示例 :
給定二叉樹
返回 3, 它的長度是路徑 [4,2,1,3] 或者 [5,2,1,3]。
求左右孩子深度的和的最大值
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: int res=0; //定義一個全局變量 int depth(TreeNode* root){ //求深度 if(root==nullptr) return 0; int L=depth(root->left); int R=depth(root->right); res=max(res,L+R); return max(L,R)+1; } int diameterOfBinaryTree(TreeNode* root) { depth(root); return res; } };
示例 1:
首先那么要合入兩個二叉樹,那么參數(shù)至少是要傳入兩個二叉樹的根節(jié)點,返回值就是合并之后二叉樹的根節(jié)點。
代碼如下:
TreeNode* mergeTrees(TreeNode* t1, TreeNode* t2)
因為是傳入了兩個樹,那么就有兩個樹遍歷的節(jié)點t1 和 t2,如果t1 == NULL 了,兩個樹合并就應(yīng)該是 t2 了?。ㄈ绻鹴2也為NULL也無所謂,合并之后就是NULL)。
反過來如果t2 == NULL,那么兩個數(shù)合并就是t1(如果t1也為NULL也無所謂,合并之后就是NULL)。
代碼如下:
if (t1 == NULL) return t2; // 如果t1為空,合并之后就應(yīng)該是t2
if (t2 == NULL) return t1; // 如果t2為空,合并之后就應(yīng)該是t1
單層遞歸的邏輯就比較好些了,這里我們用重復(fù)利用一下t1這個樹,t1就是合并之后樹的根節(jié)點(就是修改了原來樹的結(jié)構(gòu))。
那么單層遞歸中,就要把兩棵樹的元素加到一起。
t1->val += t2->val;
接下來t1 的左子樹是:合并 t1左子樹 t2左子樹之后的左子樹。
t1 的右子樹:是 合并 t1右子樹 t2右子樹之后的右子樹。
最終t1就是合并之后的根節(jié)點。
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) { // 判空 if(root1==nullptr) return root2; if(root2==nullptr) return root1; // 修改了t1的數(shù)值和結(jié)構(gòu) root1->val+=root2->val; root1->left=mergeTrees(root1->left,root2->left); root1->right=mergeTrees(root1->right,root2->right); return root1; } };
以上是“C++中二叉樹直徑與合并的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。