【Leetcode -2236.判断根节点是否等于子节点之和 -2331.计算布尔二叉树的值】

简介: 【Leetcode -2236.判断根节点是否等于子节点之和 -2331.计算布尔二叉树的值】

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);
    }
目录
相关文章
|
18天前
|
存储 SQL 算法
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
|
13天前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-2
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
13天前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-1
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
13天前
|
算法
二刷力扣--二叉树(3)
二刷力扣--二叉树(3)
|
13天前
二刷力扣--二叉树(2)
二刷力扣--二叉树(2)
|
13天前
二刷力扣--二叉树(1)基础、遍历
二刷力扣--二叉树(1)基础、遍历
|
18天前
|
存储 算法 数据可视化
力扣156题最全解法:如何上下翻转二叉树(递归与迭代方法详解,附图解)
力扣156题最全解法:如何上下翻转二叉树(递归与迭代方法详解,附图解)
|
18天前
|
算法 数据挖掘 大数据
深入解析力扣172题:阶乘后的零(计算因子5的方法详解及模拟面试问答)
深入解析力扣172题:阶乘后的零(计算因子5的方法详解及模拟面试问答)
|
18天前
|
算法 数据可视化 数据挖掘
哈希表+DFS快速解决力扣129题:求根节点到叶节点数字之和
哈希表+DFS快速解决力扣129题:求根节点到叶节点数字之和
|
18天前
|
存储 机器学习/深度学习 算法
LeetCode 题目 102:二叉树的层序遍历
LeetCode 题目 102:二叉树的层序遍历