二叉樹(shù)的最大深度

給定一個(gè)二叉樹(shù),找出其最大深度。

二叉樹(shù)的深度為根節(jié)點(diǎn)到最遠(yuǎn)葉子節(jié)點(diǎn)的最長(zhǎng)路徑上的節(jié)點(diǎn)數(shù)。

說(shuō)明: 葉子節(jié)點(diǎn)是指沒(méi)有子節(jié)點(diǎn)的節(jié)點(diǎn)。

示例:
給定二叉樹(shù) [3,9,20,null,null,15,7],

image.png

返回它的最大深度 3 。

思路1(dfs)

int maxDepth(struct TreeNode* root) {
    if(root==NULL){
        return 0;
    }
    int leftDepth=maxDepth(root->left)+1;
    int rightDepth=maxDepth(root->right)+1;
    
    if(leftDepth>rightDepth){
        return leftDepth;
    }else{
        return rightDepth;
    }
}

思路2(bfs)

采用隊(duì)列,把一層節(jié)點(diǎn)都加進(jìn)隊(duì)列,之后一個(gè)個(gè)將隊(duì)頭刪除,并且每刪除一個(gè)隊(duì)頭,把它的左右孩子節(jié)點(diǎn)加進(jìn)來(lái)

class Solution {
public:
    int maxDepth(TreeNode* root) {
         if(root == NULL){
             return 0;
         }
                 
        queue<TreeNode*> q;
        q.push(root);
        int count=0;
        while(!q.empty()){
            count++;
            for(int i=0,n=q.size();i<n;++i){
                TreeNode* p=q.front();
                q.pop();
                if(p->left!=NULL){
                    q.push(p->left);
                }
                if(p->right!=NULL){
                    q.push(p->right);
                }
            }
        }
        return count;
    }
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 題目 給定一個(gè)二叉樹(shù),找出其最大深度。二叉樹(shù)的深度為根節(jié)點(diǎn)到最遠(yuǎn)葉子節(jié)點(diǎn)的最長(zhǎng)路徑上的節(jié)點(diǎn)數(shù)。說(shuō)明: 葉子節(jié)點(diǎn)是指...
    尼小摩閱讀 349評(píng)論 0 0
  • 104. 二叉樹(shù)的最大深度 描述 給定一個(gè)二叉樹(shù),找出其最大深度。 二叉樹(shù)的深度為根節(jié)點(diǎn)到最遠(yuǎn)葉子節(jié)點(diǎn)的最長(zhǎng)路徑上...
    GoMomi閱讀 1,296評(píng)論 0 0
  • 二叉樹(shù)的最大深度給定一個(gè)二叉樹(shù),找出其最大深度。 二叉樹(shù)的深度為根節(jié)點(diǎn)到最遠(yuǎn)葉子節(jié)點(diǎn)的最長(zhǎng)路徑上的節(jié)點(diǎn)數(shù)。 說(shuō)明:...
    one_zheng閱讀 256評(píng)論 0 0
  • 給定一個(gè)二叉樹(shù),找出其最大深度。 二叉樹(shù)的深度為根節(jié)點(diǎn)到最遠(yuǎn)葉子節(jié)點(diǎn)的最長(zhǎng)路徑上的節(jié)點(diǎn)數(shù)。 說(shuō)明: 葉子節(jié)點(diǎn)是指沒(méi)...
    1f872d1e3817閱讀 210評(píng)論 0 0
  • 1 圖一是個(gè)側(cè)臉的少女,大約不超過(guò)20歲,非常年輕;圖二是把第一幅圖做了美化,僅僅把衣服和頭發(fā)做涂色。 真的是這樣...
    思想隧道閱讀 741評(píng)論 0 2

友情鏈接更多精彩內(nèi)容