LCR 051.二叉树中最大路径和

目录

题目描述

思路解析

AC代码


题目描述

LCR 051.二叉树中最大路径和

思路解析

这道题是一道路径规划题。如果,我们将其视作图。从枚举的角度上来说 弗洛伊德算法 将是很好的一种解决手段。但是,我们的树中节点的规模告诉我们,这是痴心妄想的。

根据题目意思,一条路径序列中的节点仅出现一次也就表明这条路线是单一的,不会出现交汇的情况。那么我们不妨考虑简单情况,因为此时我们面对处理树的手段还有DFS。我们可以通过DFS来缩小问题规模。

那么,我们很快就能获取到三种情况:

1. 向左子树延申,可上传

2. 向右子树延申,可上传

3. 链接左右子树,也意味着路径规划结束,不可能在上传

最终的答案,就在这三种情况中诞生。

AC代码

/**
 * 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 {
private:
    int maxSum = INT_MIN;

public:
    int maxGain(TreeNode* node) {
        if (node == nullptr) {
            return 0;
        }
        
        // 递归计算左右子节点的最大贡献值
        // 只有在最大贡献值大于 0 时,才会选取对应子节点
        int leftGain = max(maxGain(node->left), 0);   //向左延申
        int rightGain = max(maxGain(node->right), 0); //向右延申

        // 节点的最大路径和取决于该节点的值与该节点的左右子节点的最大贡献值
        int priceNewpath = node->val + leftGain + rightGain;//连接左右,且不可上传

        // 更新答案
        maxSum = max(maxSum, priceNewpath);

        // 返回节点的最大贡献值
        return node->val + max(leftGain, rightGain);
    }

    int maxPathSum(TreeNode* root) {
        maxGain(root);
        return maxSum;
    }
};

### LeetCode LCR 077 排序链表 #### 题目描述 给定一个未排序的单向链表,返回该链表按升序排列的结果。 #### 解题思路 对于这个问题,可以采用归并排序的思想来解决。具体来说,在处理链表时,可以通过快慢指针找到中间节点,从而将链表分成两部分分别进行排序后再合并这两部分有序链表[^1]。 #### 数据结构与算法分析 此问题主要涉及的数据结构为单向链表。为了有效地对链表进行排序,采用了自底向上或自顶向下两种方式之一来进行归并排序: - **自底向上**:不需要额外空间保存结点位置,通过不断调整步长逐步完成整个列表的排序; - **自顶向下**:利用递归来实现,每次都将当前链表分为大致相等长度的两个子链表直到不能再分为止,之后再依次合并各个已排序的小段形成最终结果[^2]。 下面展示的是基于自顶向下的归并排序的具体代码实现: ```python class ListNode: def __init__(self, val=0, next=None): self.val = val self.next = next def sortList(head: ListNode) -> ListNode: if not head or not head.next: return head # 使用快慢指针寻找链表中点 slow, fast = head, head.next while fast and fast.next: slow = slow.next fast = fast.next.next mid = slow.next slow.next = None # 对前后半部各自排序 left_half_sorted = sortList(head) right_half_sorted = sortList(mid) # 合并已经排好序的部分 dummy_head = tail = ListNode() while left_half_sorted and right_half_sorted: if left_half_sorted.val < right_half_sorted.val: tail.next, left_half_sorted = left_half_sorted, left_half_sorted.next else: tail.next, right_half_sorted = right_half_sorted, right_half_sorted.next tail = tail.next tail.next = left_half_sorted if left_half_sorted is not None else right_half_sorted result = dummy_head.next del dummy_head return result ``` 上述代码实现了完整的链表排序逻辑,其中包含了如何定位链表中心以及怎样高效地执行合并操作等内容[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值