C++二叉樹的直徑與合并詳解
二叉樹的直徑
- 給定一棵二叉樹,你需要計算它的直徑長度。一棵二叉樹的直徑長度是任意兩個結(jié)點路徑長度中的最大值。這條路徑可能穿過也可能不穿過根結(jié)點。
示例 :
給定二叉樹
返回 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; } };
合并二叉樹
- 給定兩個二叉樹,想象當(dāng)你將它們中的一個覆蓋到另一個上時,兩個二叉樹的一些節(jié)點便會重疊。你需要將他們合并為一個新的二叉樹。合并的規(guī)則是如果兩個節(jié)點重疊,那么將他們的值相加作為節(jié)點合并后的新值,否則不為 NULL 的節(jié)點將直接作為新二叉樹的節(jié)點。
示例 1:
思路
1.確定遞歸函數(shù)的參數(shù)和返回值:
首先那么要合入兩個二叉樹,那么參數(shù)至少是要傳入兩個二叉樹的根節(jié)點,返回值就是合并之后二叉樹的根節(jié)點。
代碼如下:
TreeNode* mergeTrees(TreeNode* t1, TreeNode* t2)
2.確定終止條件:
因為是傳入了兩個樹,那么就有兩個樹遍歷的節(jié)點t1 和 t2,如果t1 == NULL 了,兩個樹合并就應(yīng)該是 t2 了啊(如果t2也為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
3.確定單層遞歸的邏輯:
單層遞歸的邏輯就比較好些了,這里我們用重復(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; } };
總結(jié)
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
簡述C語言中system()函數(shù)與vfork()函數(shù)的使用方法
這篇文章主要介紹了簡述C語言中system()函數(shù)與vfork()函數(shù)的使用方法,是C語言入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-08-08C++構(gòu)造函數(shù)的一些注意事項總結(jié)
構(gòu)造函數(shù)是創(chuàng)建類對象,并且在創(chuàng)建完成前,對類進(jìn)行初始化的特殊函數(shù),下面這篇文章主要給大家介紹了關(guān)于C++構(gòu)造函數(shù)的一些注意事項,需要的朋友可以參考下2021-11-11深入HRESULT與Windows Error Codes的區(qū)別詳解
本篇文章是對HRESULT與Windows Error Codes的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C語言驅(qū)動開發(fā)之內(nèi)核使用IO/DPC定時器詳解
本章將繼續(xù)探索驅(qū)動開發(fā)中的基礎(chǔ)部分,定時器在內(nèi)核中同樣很常用,在內(nèi)核中定時器可以使用兩種,即IO定時器,以及DPC定時器,感興趣的可以了解一下2023-04-04