【二叉树】最大二叉树

0x00 题目

给定一个不重复的整数数组 nums
构建一个 最大 二叉树
最大二叉树可以用下面的算法从 nums 递归地构建:
创建一个 根节点,其值为 nums 中的最大值
递归地在最大值 左边 的子数组前缀上 构建 左子树
递归地在最大值 右边 的子数组后缀上 构建 右子树
返回 nums 构建的 最大二叉树


0x01 思路

找到数组中的 最大数
构建 根节点
根据索引把数组 一分为二
对两个数组进行 递归 操作


0x02 解法

语言:Swift

树节点:TreeNode

public class TreeNode {
    public var val: Int
    public var left: TreeNode?
    public var right: TreeNode?
    public init() { self.val = 0; self.left = nil; self.right = nil; }
    public init(_ val: Int) { self.val = val; self.left = nil; self.right = nil; }
    public init(_ val: Int, _ left: TreeNode?, _ right: TreeNode?) {
        self.val = val
        self.left = left
        self.right = right
    }
}

解法:

func constructMaximumBinaryTree(_ nums: [Int]) -> TreeNode? {
    if nums.isEmpty { return nil }
    
    // 查找数组中最大数的索引
    var index: Int = 0
    for i in 0..<nums.count {
        if nums[index] < nums[i] {
            index = i
        }
    }
    
    // 构建根节点
    let root = TreeNode(nums[index])
    // 递归构建左子树
    root.left = constructMaximumBinaryTree(Array(nums[0..<index]))
    // 递归构建右子树
    root.right = constructMaximumBinaryTree(Array(nums[(index+1)...]))
    
    return root
}

0x03 我的作品

欢迎体验我的作品之一:小五笔 86 版
五笔学习的好帮手
App Store 搜索即可~


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

豪冷啊

你的鼓励是对我的认可!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值