欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++二叉樹的直徑與合并詳解

 更新時間:2021年09月10日 09:04:28   作者:久病成良醫(yī)  
這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)二叉樹基本操作,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能給你帶來幫助

二叉樹的直徑

  • 給定一棵二叉樹,你需要計算它的直徑長度。一棵二叉樹的直徑長度是任意兩個結(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語言中system()函數(shù)與vfork()函數(shù)的使用方法,是C語言入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-08-08
  • C++構(gòu)造函數(shù)的一些注意事項總結(jié)

    C++構(gòu)造函數(shù)的一些注意事項總結(jié)

    構(gòu)造函數(shù)是創(chuàng)建類對象,并且在創(chuàng)建完成前,對類進(jìn)行初始化的特殊函數(shù),下面這篇文章主要給大家介紹了關(guān)于C++構(gòu)造函數(shù)的一些注意事項,需要的朋友可以參考下
    2021-11-11
  • 使用Matlab制作大富翁小游戲的過程詳解

    使用Matlab制作大富翁小游戲的過程詳解

    大富翁大家都玩過,走到建筑的位置可以買地,第二圈走到買過的地可以升級,別人經(jīng)過后需要付過路費,每次經(jīng)過起點都會獲得一定資金,玩到最后還沒破產(chǎn)的就是勝者,本文將制作一個Matlab版的大富翁小游戲,需要的可以參考一下
    2022-02-02
  • 深入HRESULT與Windows Error Codes的區(qū)別詳解

    深入HRESULT與Windows Error Codes的區(qū)別詳解

    本篇文章是對HRESULT與Windows Error Codes的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C++深入細(xì)致探究二叉搜索樹

    C++深入細(xì)致探究二叉搜索樹

    二叉搜索樹是以一棵二叉樹來組織的。每個節(jié)點是一個對象,包含的屬性有l(wèi)eft,right,p和key,其中,left指向該節(jié)點的左孩子,right指向該節(jié)點的右孩子,p指向該節(jié)點的父節(jié)點,key是它的值
    2022-05-05
  • C++設(shè)計模式之橋接模式(Bridge)

    C++設(shè)計模式之橋接模式(Bridge)

    這篇文章主要為大家詳細(xì)介紹了C++設(shè)計模式之橋接模式Bridge,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • C++如何有效地利用命名空間

    C++如何有效地利用命名空間

    談到C++編程中的模塊化和組織性時,命名空間(Namespace)是一個重要的概念,所以本文主要來和大家聊聊C++命名空間的概念、用法以及如何有效地利用它來管理代碼,有需要的可以參考下
    2023-09-09
  • C語言驅(qū)動開發(fā)之內(nèi)核使用IO/DPC定時器詳解

    C語言驅(qū)動開發(fā)之內(nèi)核使用IO/DPC定時器詳解

    本章將繼續(xù)探索驅(qū)動開發(fā)中的基礎(chǔ)部分,定時器在內(nèi)核中同樣很常用,在內(nèi)核中定時器可以使用兩種,即IO定時器,以及DPC定時器,感興趣的可以了解一下
    2023-04-04
  • C/C++時間庫chrono的使用總結(jié)

    C/C++時間庫chrono的使用總結(jié)

    std::chrono是C++標(biāo)準(zhǔn)庫中的一個組件,用于表示和處理時間,其功能就像是心理學(xué)中的感知系統(tǒng),它可以為我們捕捉、量化并操作抽象的時間概念,這就如同我們的大腦可以理解和感知周圍環(huán)境的時間流逝一樣,這種感知和理解能力是人類進(jìn)行日常活動所必需的,
    2023-12-12
  • C++ VTK實例之高斯隨機數(shù)的生成

    C++ VTK實例之高斯隨機數(shù)的生成

    這篇文章主要介紹了VTK的一個實例之高斯隨機數(shù)的生成,本文演示了從一個平均數(shù)是0.0和標(biāo)準(zhǔn)偏差是2.2的高斯分布中隨機生成3個隨機數(shù)。感興趣的同學(xué)可以學(xué)習(xí)一下
    2021-11-11

最新評論