博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
力扣题解-112. 路径总和(分治法思想,递归的方式求解)
阅读量:4300 次
发布时间:2019-05-27

本文共 1060 字,大约阅读时间需要 3 分钟。

题目:112. 路径总和

给定一个二叉树和一个目标和,判断该树中是否存在根节点到叶子节点的路径,这条路径上所有节点值相加等于目标和。

说明: 叶子节点是指没有子节点的节点。

示例:

给定如下二叉树,以及目标和 sum = 22,

5         / \        4   8       /   / \      11  13  4     /  \      \    7    2      1

返回 true, 因为存在目标和为 22 的根节点到叶子节点的路径 5->4->11->2。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/path-sum
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解

  1. divide

    将原始二叉树分为左子树和右子树。

  2. conquer

    原问题的解hasPathSum(root, sum)分为左子树的解 hasPathSum(left, sum - root->val) 和右子树的解 hasPathSum(right, sum - root->val) 。

  3. combine

    将左右子树的解取逻辑或,得到原问题的解。

代码

/** * Definition for a binary tree node. * struct TreeNode { *     int val; *     TreeNode *left; *     TreeNode *right; *     TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */class Solution {
public: bool hasPathSum(TreeNode* root, int sum) {
if (!root) {
return false; } if (!root->left and !root->right) {
return root->val == sum ? true: false; } return hasPathSum(root->left, sum - root->val) or hasPathSum(root->right, sum - root->val); }};
你可能感兴趣的文章
java 用流收集数据
查看>>
java并行流
查看>>
CompletableFuture 组合式异步编程
查看>>
mysql查询某一个字段是否包含中文字符
查看>>
Java中equals和==的区别
查看>>
JVM内存管理及GC机制
查看>>
Java:按值传递还是按引用传递详细解说
查看>>
全面理解Java内存模型
查看>>
Java中Synchronized的用法
查看>>
阻塞队列
查看>>
linux的基础知识
查看>>
接口技术原理
查看>>
五大串口的基本原理
查看>>
PCB设计技巧与注意事项
查看>>
linux进程之间通讯常用信号
查看>>
main函数带参数
查看>>
PCB布线技巧
查看>>
关于PCB设计中过孔能否打在焊盘上的两种观点
查看>>
PCB反推理念
查看>>
京东技术架构(一)构建亿级前端读服务
查看>>