2023-09-18 LeetCode每日一题(打家劫舍 III)

2023-09-18每日一题

一、题目编号

复制代码
337. 打家劫舍 III

二、题目链接

点击跳转到题目位置

三、题目描述

小偷又发现了一个新的可行窃的地区。这个地区只有一个入口,我们称之为 root 。

除了 root 之外,每栋房子有且只有一个"父"房子与之相连。一番侦察之后,聪明的小偷意识到"这个地方的所有房屋的排列类似于一棵二叉树"。 如果 两个直接相连的房子在同一天晚上被打劫 ,房屋将自动报警。

给定二叉树的 root 。返回 在不触动警报的情况下 ,小偷能够盗取的最高金额 。

示例 1:

示例 2:

提示:

  • 树的节点数在 [1, 104] 范围内
  • 0 <= Node.val <= 104

四、解题代码

cpp 复制代码
class Solution {
public:
    unordered_map <TreeNode*, int> f, g;

    void dfs(TreeNode* node) {
        if (!node) {
            return;
        }
        dfs(node->left);
        dfs(node->right);
        f[node] = node->val + g[node->left] + g[node->right];
        g[node] = max(f[node->left], g[node->left]) + max(f[node->right], g[node->right]);
    }

    int rob(TreeNode* root) {
        dfs(root);
        return max(f[root], g[root]);
    }
};

五、解题思路

(1) 树型dp题目

相关推荐
木子n113 小时前
第2篇:坐标变换与数学基础:FOC算法的核心数学工具
算法·电机控制·foc
阿Y加油吧13 小时前
两道经典 DP 题:零钱兑换 & 单词拆分(完全背包 + 字符串 DP)
算法
疯狂打码的少年13 小时前
有序线性表删除一个元素:顺序存储 vs 单链表,平均要移动多少个元素?
数据结构·算法·链表
y = xⁿ13 小时前
20天速通LeetCode day07:前缀和
数据结构·算法·leetcode
小雅痞13 小时前
[Java][Leetcode hard] 42. 接雨水
java·开发语言·leetcode
载数而行52014 小时前
算法集训1:模拟,枚举,错误分析,前缀和,差分
算法
hehelm14 小时前
vector模拟实现
前端·javascript·算法
Tina学编程15 小时前
[HOT 100]今日一练------划分字母区间
算法·hot 100
RTC老炮15 小时前
RaptorQ前向纠错算法架构分析
网络·算法·架构·webrtc
故事和你9115 小时前
洛谷-数据结构1-1-线性表2
开发语言·数据结构·算法·动态规划·图论