[LeetCode] 437. 路径总和 III ☆☆☆(递归)
路径总和 III
描述
给定一个二叉树,它的每个结点都存放着一个整数值。
找出路径和等于给定数值的路径总数。
路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点)。
二叉树不超过1000个节点,且节点数值范围是 [-1000000,1000000] 的整数。
示例:
root = [10,5,-3,3,2,null,11,3,-2,null,1], sum = 8
10
     /  \
    5   -3
   / \    \
  3   2   11
 / \   \
3  -2   1
返回 3。和等于 8 的路径有:
1.  5 -> 3
2.  5 -> 2 -> 1
3.  -3 -> 11
解析
1. 遍历每个节点。 关键点:递归
2. 计算以当前节点为路径终点的所有路径和。 关键点:用一个数组保存从根节点到当前节点路径
代码
public int pathSum(TreeNode root, int sum) {
        if (null == root) {
            return 0;
        }
        return pathSumHelp(root, new int[1000], sum, 0);
    }
    /**
     *
     * @param root
     * @param array 保存路径的数组
     * @param sum
     * @param curIndex 当前的数组index
     * @return
     */
    public int pathSumHelp(TreeNode root, int[] array, int sum, int curIndex) {
        if (null == root) {
            return 0;
        }
        int curNum = root.val == sum ? 1 : 0;
        int curSum = root.val;
        for (int i = curIndex - 1; i >= 0; i--) {
            curSum += array[i];
            if (curSum == sum) {
                curNum++;
            }
        }
        array[curIndex] = root.val;
        int leftNum = pathSumHelp(root.left, array, sum, curIndex + 1);
        int rightNum = pathSumHelp(root.right, array, sum, curIndex + 1);
        return curNum + leftNum + rightNum;
    }
复杂度
遍历n个节点,为每个节点计算以当前节点为路径终点的所有路径和,平均路径长度是logn,所以平均时间复杂度是O(nlogn)
[LeetCode] 437. 路径总和 III ☆☆☆(递归)的更多相关文章
- Java实现 LeetCode 437 路径总和 III(三)
		437. 路径总和 III 给定一个二叉树,它的每个结点都存放着一个整数值. 找出路径和等于给定数值的路径总数. 路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点 ... 
- Leetcode 437.路径总和III
		路径总和III 给定一个二叉树,它的每个结点都存放着一个整数值. 找出路径和等于给定数值的路径总数. 路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点). ... 
- leetcode 437. 路径总和 III
		题目描述: 给定一个二叉树,它的每个结点都存放着一个整数值. 找出路径和等于给定数值的路径总数. 路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点). 二 ... 
- 【LeetCode】437. 路径总和 III
		437. 路径总和 III 给定一个二叉树,它的每个结点都存放着一个整数值. 找出路径和等于给定数值的路径总数. 路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点 ... 
- 437. 路径总和 III
		方法一:48 ms /* sumUp递归子程序求解以root为根节点的子节点之和为sum的路径数目; pathSum递归部分是把根节点逐一考察,如以root->left,以root->ri ... 
- 437路径总和III
		题目: 给定一个二叉树,它的每个结点都存放着一个整数值.找出路径和等于给定数值的路径总数.路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点).来源: ht ... 
- LeetCode 112. 路径总和 (递归遍历二叉树)
		题目链接:https://leetcode-cn.com/problems/path-sum/ 给定一个二叉树和一个目标和,判断该树中是否存在根节点到叶子节点的路径,这条路径上所有节点值相加等于目标和 ... 
- [二叉树-根到叶的子路径]路径总和 III (两层递归)
		题目437. 路径总和 III 给定一个二叉树,它的每个结点都存放着一个整数值. 找出路径和等于给定数值的路径总数. 路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父 ... 
- LeetCode 112. 路径总和(Path Sum) 10
		112. 路径总和 112. Path Sum 题目描述 给定一个二叉树和一个目标和,判断该树中是否存在根节点到叶子节点的路径,这条路径上所有节点值相加等于目标和. 说明: 叶子节点是指没有子节点的节 ... 
随机推荐
- OSI七层模型、TCP/IP五层模型
			OSI网络互连的七层框架:物理层.数据链路层.网络层.传输层.会话层.表示层.应用层: <1>应用层 OSI参考模型中最靠近用户的一层,是为计算机用户提供应用接口,为用户直接提供各种网络服 ... 
- 将pip源设置国内源
			windows (1)打开文件资源管理器(文件夹地址栏中) (2)地址栏上面输入 %appdata% (3)在这里面新建一个文件夹 pip (4)在pip文件夹里面新建一个文件叫做 pip.ini , ... 
- php的工厂模式
			特点 :将调用者和创建者分离,调用者直接向工厂类请求获取调用对象,减少代码耦合,提高系统的维护性和扩展性. <?php // **** 共同接口 **** // interface DB { f ... 
- CentOS / RHEL 内核升级
			1. 查看当前内核版本 [root@192.168.118.11 ~]#cat /etc/redhat-release CentOS Linux release 7.7.1908 (Core) [ro ... 
- web page popup window model
			jQuery UI dialog: https://jqueryui.com/dialog/ Semantic UI https://semantic-ui.com/modules/modal.htm ... 
- VS2015 控制台cl编译器全局环境变量配置
			Visual C++的cl.exe编译器是微软推出的编译器 为了可以在CMD里使用cl.exe手工执行编译操作 设置环境变量 PATH C:\Program Files (x86)\Microsoft ... 
- 【视频开发】ONVIF客户端搜索设备获取rtsp地址开发笔记(精华篇)
			转载地址:http://blog.csdn.net/gubenpeiyuan/article/details/25618177 概要: 目前ONVIF协议家族设备已占据数字监控行业 ... 
- 进程退出:SIGINT、SIGTERM和SIGKILL区别
			一.SIGINT.SIGTERM和SIGKILL区别 SIGINT与SIGTERM区别1)SIGINT关联ctrl+c2)SIGINT只能结束前台进程3)通过ctrl+c对当前进程发送结束信号,信号被 ... 
- IDEA和JIRA任务联动(redmine同理)
			IDEA和JIRA任务联动-操作流程详解 redmine和这个步骤类似,只是第一步选择的工具不一样 操作流程 添加jira配置,File->Setting-->tools-->Tas ... 
- docker 实战-项目部署
			前面学习了 docker 的命令和实际的用法,现在来实战一下.编排一个服务,也就是项目部署. 目前我们在一个闭源环境下工作,介绍一些工作流程和部署项目的方法. 该工作流程比较特殊 所谓闭源环境就是 没 ... 
