打家劫舍3

class Solution {

public:

pair<int,int> dfs(TreeNode* root) {

if(!root)return {0,0} ;

pair<int,int> l=dfs(root->left);

pair<int,int> r=dfs(root->right);

int choose=root->val+l.second+r.second;//如果选这个节点,那么他的子节点都不能选

int nochoose=max(l.first,l.second)+max( r.first,r.second);//如果不选,取子节点选与不选时得到的最大值

return {choose,nochoose};

}

int rob(TreeNode* root) {

pair<int,int>res=dfs(root);

return max(res.first,res.second);

}

};

相关推荐
历程里程碑2 小时前
Protobuf 环境搭建:Windows 与 Linux 系统安装教程
linux·运维·数据结构·windows·线性代数·算法·矩阵
keep intensify2 小时前
岛屿数量--
算法·深度优先
代码探秘者2 小时前
【算法】吃透18种Java 算法快速读写模板
数据结构·数据库·python·算法·spring
2301_816651222 小时前
C++模块化设计原则
开发语言·c++·算法
gaozhiyong08132 小时前
提示词的解剖学:Gemini 3.1 Pro 提示工程高级策略与国内实战
人工智能·算法·机器学习
小范自学编程3 小时前
算法训练营Day44 - 动态规划part12
算法·动态规划
。。,……~3 小时前
RGB-IR融合算法CDDFUSE理解+复现
算法
小刘的AI小站3 小时前
L9 Policy Gradient Method (二)
算法·机器学习·强化学习
WolfGang0073213 小时前
代码随想录算法训练营 Day21 | 回溯算法 part03
数据结构·算法