《算法题讲解指南:递归,搜索与回溯算法--二叉树中的深搜》--6.计算布尔二叉树的值,7.求根节点到叶节点数字之和

《算法题讲解指南:递归,搜索与回溯算法--二叉树中的深搜》--6.计算布尔二叉树的值,7.求根节点到叶节点数字之和

🔥小叶-duck个人主页

❄️个人专栏《Data-Structure-Learning》

《C++入门到进阶&自我学习过程记录》

《算法题讲解指南》--优选算法

《算法题讲解指南》--递归、搜索与回溯算法

未择之路,不须回头
已择之路,纵是荆棘遍野,亦作花海遨游


目录

深度优先遍历介绍

6.计算布尔二叉树的值

题目链接:

题目描述:

题目示例:

解法(递归):

算法思路:

C++算法代码:

7.求根节点到叶节点数字之和

题目链接:

题目描述:

题目示例:

解法(dfs-前序遍历):

算法思路:

C++算法代码:

算法总结及流程解析:

结束语


深度优先遍历介绍

      深度优先遍历(DFS,全称为 Depth First Traversal),是我们树或者图这样的数据结构中常用的一种遍历算法。这个算法会尽可能深的搜索树或者图的分支,直到一条路径上的所有节点都被遍历完毕,然后再回溯到上一层,继续找一条路遍历。
      在二叉树中,常见的深度优先遍历为:前序遍历、中序遍历以及后序遍历
      因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不仅容易理解而且代码很简洁。并且前中后序三种遍历的唯一区别就是访问根节点的时机不同,在做题的时候,选择一个适当的遍历顺序,对于算法的理解是非常有帮助的。

6.计算布尔二叉树的值

题目链接:

2331. 计算布尔二叉树的值 - 力扣(LeetCode)

题目描述:

题目示例:

解法(递归):

算法思路:

      本题可以被解释为:
      1.对于规模为 n 的问题,需要求得当前节点值。
      2.节点值不为 0或1 时,规模为 n 的问题可以被拆分为规模为 n-1 的子问题:
          a.所有子节点的值;
          b.通过子节点的值运算出当前节点值。
      3.当问题的规模变为 n=1 时,即叶子节点的值为 0或1,我们可以直接获取当前节点值为 0或1。

C++算法代码:

/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: bool evaluateTree(TreeNode* root) { //解法:递归(dfs) //递归结束条件:当结点没有左右孩子时返回该结点值 if(root->left == nullptr && root->right == nullptr) { return root->val; //因为到递归结束时也就是到叶子结点时,因为叶子结点只有0和1两个值 //并且这两个值就可以代表false和true,所以直接返回root->val即可 } root->left->val = evaluateTree(root->left); root->right->val = evaluateTree(root->right); return root->val == 2 ? root->left->val || root->right->val : root->left->val && root->right->val; } };

7.求根节点到叶节点数字之和

题目链接:

129. 求根节点到叶节点数字之和 - 力扣(LeetCode)

题目描述:

题目示例:

解法(dfs-前序遍历):

      前序遍历按照根节点、左子树、右子树的顺序遍历二叉树的所有节点,通常用于子节点的状态依赖于父节点状态的题目。

算法思路:

      在前序遍历的过程中,我们可以往左右子树传递信息,并且在回溯时得到左右子树的返回值。递归函数可以帮我们完成两件事:

      1.将父节点的数字与当前节点的信息整合到一起,计算出当前节点的数字,然后传递到下一层进行递归;
      2.当遇到叶子节点的时候,就不再向下传递信息,而是将整合的结果向上一直回溯到根节点

      在递归结束时,根节点需要返回的值也就被更新为了整棵树的数字和。

C++算法代码:

/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: int sumNumbers(TreeNode* root) { if(root->left == nullptr && root->right == nullptr) { return root->val; } int leftsum = 0, rightsum = 0; if(root->left) { TreeNode* left = root->left; left->val = root->val * 10 + root->left->val; leftsum = sumNumbers(left); } if(root->right) { TreeNode* right = root->right; right->val = root->val * 10 + root->right->val; rightsum = sumNumbers(right); } return leftsum + rightsum; } };

算法总结及流程解析:

结束语

      到此,6.计算布尔二叉树的值,7.求根节点到叶节点数字之和 这两道算法题就讲解完了。计算布尔二叉树的值 通过递归求解子节点值,再根据运算符计算当前节点值; 求根节点到叶节点数字之和 采用前序遍历方式,在递归过程中传递并累加节点数值。希望大家能有所收获!

Read more

【LeetCode_206】反转链表

【LeetCode_206】反转链表

刷爆LeetCode系列 * LeetCode第206题:反转链表 * github地址 * 前言 * 题目描述 * 题目与思路分析 * 思路一:反转链表的指针指向 * 思路二:取链表的结点,头插到新链表中 * 代码实现 * 思路一:反转指针指向 * 以下两种写法是保存curNext指针的方式不同 * 思路二:取原链表中的节点,头插到新链表 * 试错代码 * 算法代码优化 * 思路一优化: LeetCode第206题:反转链表 github地址 有梦想的电信狗 前言 本文用C++实现LeetCode第206题:反转链表 题目描述 * 题目链接:https://leetcode-cn.com/problems/reverse-linked-list/description/ 题目与思路分析 目标分析: 1. 有单链表的头节点 head ,反转原链表 2. 返回反转后的链表的头指针 3. 提高要求:时间复杂度为O(n)

By Ne0inhk
【组合数学 动态规划】P6870 [COCI2019-2020#5] Zapina|普及+

【组合数学 动态规划】P6870 [COCI2019-2020#5] Zapina|普及+

本文涉及知识点 组合数学汇总 C++动态规划 [COCI2019-2020#5] Zapina 题目描述 有 n n n 个不同的人和 n n n 道不同的题。 第 i i i 个人开心当且仅当他被分配到 i i i 道题,题号不限。 求让至少一个人开心的分配方案数。 输入格式 一个正整数: n n n。 输出格式 一个数字:你的答案 m o d 10 9 + 7 \bmod 10^9+7 mod109+7。 样例 #1

By Ne0inhk
极致性能的服务器Redis之Hash类型及相关指令介绍

极致性能的服务器Redis之Hash类型及相关指令介绍

目录 1. Hash介绍 2. hset 3. hget 3. hdel 5. hkeys 6. hvals 编辑 7. hgetall  8. hexists 9. hmget 10. hlen 11. hsetnx 12. hincrby 13. hincrbyfloat 1. Hash介绍 Redis 哈希类型是键值对的集合,字段与值均支持字符串、数字等类型,适合建模用户信息、配置项等对象类数据。其支持单字段 / 多字段的增删改查、字段存在性判断、值自增自减等原子操作,且底层通过压缩列表或哈希表优化存储,空间利用率高、查询效率快,是 Redis 中存储结构化数据的核心类型之一。 在Redis中因为本身就是按照哈希的KV结构来进行存储的,所以当我们想要使用Redis里面的哈希的时候,实际上是哈希的哈希,在后者中,

By Ne0inhk
【算法一周目】数据深处的舞者:二分查找的优雅与力量

【算法一周目】数据深处的舞者:二分查找的优雅与力量

文章目录 * 1.二分查找 * 2.在排序数组中查找元素的第一个和最后一个位置 * 3.搜索插入位置 * 4. x 的平方根 * 5.山峰数组的峰顶 * 6.寻找峰值 * 7.搜索旋转排序数组中的最小值 * 8.0~n-1 中缺失的数字 1.二分查找 题目链接:704. 二分查找 题目描述: 给定一个升序排列的整数数组 nums,和一个目标值 target。如果 target 在数组中存在,返回其下标;否则,返回 -1。 示例 1: * 输入:nums = [-1,0,3,5,9,12], target = 9 * 输出:

By Ne0inhk