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

Leetcode

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

Leetcode -2236.判断根节点是否等于子节点之和

题目:给你一个 二叉树 的根结点 root,该二叉树由恰好 3 个结点组成:根结点、左子结点和右子结点。
如果根结点值等于两个子结点值之和,返回 true ,否则返回 false 。

示例 1:
【Leetcode -2236.判断根节点是否等于子节点之和 -2331.计算布尔二叉树的值】_第1张图片

输入:root = [10, 4, 6]
输出:true
解释:根结点、左子结点和右子结点的值分别是 10 、4 和 6 。
由于 10 等于 4 + 6 ,因此返回 true 。

示例 2:
【Leetcode -2236.判断根节点是否等于子节点之和 -2331.计算布尔二叉树的值】_第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:
【Leetcode -2236.判断根节点是否等于子节点之和 -2331.计算布尔二叉树的值】_第3张图片

输入: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);
		}

你可能感兴趣的:(leetcode,算法,c语言,数据结构)