LeetCode之Diameter of Binary Tree(Kotlin)

问题:



方法:
DFS问题的变种,在遍历过程中在每个节点获取左子树与右子树的最大深度,然后计算左右深度和,取所有节点中最大的和即为结果。

package com.eric.leetcode

class DiameterOfBinaryTree {
    var result = 0;
    fun diameterOfBinaryTree(root: TreeNode?): Int {
        diameter(root)
        return result
    }

    private fun diameter(root: TreeNode?): Int {
        if (root == null) {
            return 0
        }

        val left = diameter(root.left)
        val right = diameter(root.right)

        result = maxOf(1 + left + right, result)
        return 1 + maxOf(left, right)
    }
}

有问题随时沟通

具体代码实现可以参考Github

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容