Leetcode -2236.判断根节点是否等于子节点之和
题目:给你一个 二叉树 的根结点 root,该二叉树由恰好 3 个结点组成:根结点、左子结点和右子结点。
如果根结点值等于两个子结点值之和,返回 true ,否则返回 false 。
示例 1:
输入:root = [10, 4, 6]
输出:true
解释:根结点、左子结点和右子结点的值分别是 10 、4 和 6 。
由于 10 等于 4 + 6 ,因此返回 true 。
示例 2:
输入:root = [5, 3, 1]
输出:false
解释:根结点、左子结点和右子结点的值分别是 5 、3 和 1 。
由于 5 不等于 3 + 1 ,因此返回 false 。
提示:
树只包含根结点、左子结点和右子结点
- 100 <= Node.val <= 100
思路:直接返回判断根的值是否等于左节点和右节点 val 之和;
bool checkTree(struct TreeNode* root) { //直接返回判断根的值是否等于左节点和右节点 val 之和 return root->val == root->left->val + root->right->val; }
Leetcode -2331.计算布尔二叉树的值
题目:给你一棵 完整二叉树 的根,这棵树有以下特征:
叶子节点 要么值为 0 要么值为 1 ,其中 0 表示 False ,1 表示 True 。
非叶子节点 要么值为 2 要么值为 3 ,其中 2 表示逻辑或 OR ,3 表示逻辑与 AND 。
计算 一个节点的值方式如下:
如果节点是个叶子节点,那么节点的 值 为它本身,即 True 或者 False 。
否则,计算 两个孩子的节点值,然后将该节点的运算符对两个孩子值进行 运算 。
返回根节点 root 的布尔运算值。
完整二叉树 是每个节点有 0 个或者 2 个孩子的二叉树。
叶子节点 是没有孩子的节点。
示例 1:
输入:root = [2, 1, 3, null, null, 0, 1]
输出:true
解释:上图展示了计算过程。
AND 与运算节点的值为 False AND True = False 。
OR 运算节点的值为 True OR False = True 。
根节点的值为 True ,所以我们返回 true 。
示例 2:
输入:root = [0]
输出:false
解释:根节点是叶子节点,且值为 false,所以我们返回 false 。
提示:
树中节点数目在 [1, 1000] 之间。
0 <= Node.val <= 3
每个节点的孩子数为 0 或 2 。
叶子节点的值为 0 或 1 。
非叶子节点的值为 2 或 3 。
思路:如果 val == 2 或 3,返回左子树和右子树对应的逻辑运算,如果是 0 或 1,返回 false 或 true;
bool evaluateTree(struct TreeNode* root) { //节点的值为1,返回true if (root->val == 1) return true; //节点的值为0,返回false if (root->val == 0) return false; //节点的值为2,将左子树和右子树进行逻辑或计算 if (root->val == 2) return evaluateTree(root->left) || evaluateTree(root->right); //节点的值为3,将左子树和右子树进行逻辑与计算 return evaluateTree(root->left) && evaluateTree(root->right); }