题目描述

  输入一棵二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径。从树的根节点开始往下一直到叶节点所经过的节点形成一条路径
  
  

  输入上图二叉树以及22,可以打印出两条路径,[10,12] 和[10,5,7]
  
  

牛客网刷题地址

思路分析

  递归的前序遍历二叉树 ,将沿途路径中的值添加到list中,每次与target相减,当target减为0且遍历到子结点时,这条路径就是符合条件的路径,继续寻找。

测试用例

  1. 功能测试:二叉树中有一条、多条符合要求的路径;二叉树中没有符合要求的路径。
  2. 特殊输入测试:指向二叉树根节点的指针为nullptr指针。

Java代码

  1. public class Offer34 {
  2. public static void main(String[] args) {
  3. test1();
  4. test2();
  5. test3();
  6. }
  7. public static ArrayList<ArrayList<Integer>> FindPath(TreeNode root,int target) {
  8. return Solution1(root,target);
  9. }
  10. private static ArrayList<ArrayList<Integer>> Solution1(TreeNode root,int target) {
  11. ArrayList<ArrayList<Integer>> pathList=new ArrayList<ArrayList<Integer>>();
  12. if(root==null)
  13. return pathList;
  14. ArrayList<Integer> nodeList=new ArrayList<Integer>();
  15. findPathCore(root,target,pathList,nodeList);
  16. return pathList;
  17. }
  18. private static void findPathCore(TreeNode root,int target,ArrayList<ArrayList<Integer>> pathList, ArrayList<Integer> nodeList) {
  19. if(root == null) return;
  20. nodeList.add(root.val);
  21. target-=root.val;
  22. if(target==0 && root.left==null && root.right==null) {
  23. int i=0;
  24. while(i<pathList.size() && nodeList.size()<pathList.get(i).size()) {
  25. i++;
  26. }
  27. pathList.add(i,new ArrayList<Integer>(nodeList));
  28. }else {
  29. findPathCore(root.left, target,pathList,nodeList);
  30. findPathCore(root.right, target,pathList,nodeList);
  31. }
  32. nodeList.remove(nodeList.size()-1);
  33. }
  34. private static void test1() {
  35. TreeNode root = new TreeNode(8);
  36. TreeNode node1 = new TreeNode(6);
  37. TreeNode node2 = new TreeNode(10);
  38. TreeNode node3 = new TreeNode(5);
  39. TreeNode node4 = new TreeNode(7);
  40. TreeNode node5 = new TreeNode(9);
  41. TreeNode node6 = new TreeNode(11);
  42. root.left=node1;
  43. root.right=node2;
  44. node1.left=node3;
  45. node1.right=node4;
  46. node2.left=node5;
  47. node2.right=node6;
  48. TreeNode.preOrder(root);
  49. System.out.println();
  50. ArrayList<ArrayList<Integer>> findPath = FindPath(root, 27);
  51. System.out.println(findPath);
  52. }
  53. private static void test2() {
  54. }
  55. private static void test3() {
  56. }
  57. }

代码链接

剑指Offer代码-Java

【Offer】[34] 【二叉树中和为某一值的路径】的更多相关文章

  1. 剑指 Offer 34. 二叉树中和为某一值的路径 + 记录所有路径

    剑指 Offer 34. 二叉树中和为某一值的路径 Offer_34 题目详情 题解分析 本题是二叉树相关的题目,但是又和路径记录相关. 在记录路径时,可以使用一个栈来存储一条符合的路径,在回溯时将进 ...

  2. 剑指 Offer 34. 二叉树中和为某一值的路径

    剑指 Offer 34. 二叉树中和为某一值的路径 输入一棵二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径.从树的根节点开始往下一直到叶节点所经过的节点形成一条路径. 示例: 给定如下 ...

  3. 【Java】 剑指offer(34) 二叉树中和为某一值的路径

    本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 输入一棵二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有 ...

  4. 每日一题 - 剑指 Offer 34. 二叉树中和为某一值的路径

    题目信息 时间: 2019-06-27 题目链接:Leetcode tag:深度优先搜索 回溯法 难易程度:中等 题目描述: 输入一棵二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径.从 ...

  5. 剑指Offer:二叉树中和为某一值的路径【34】

    剑指Offer:二叉树中和为某一值的路径[34] 题目描述 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. ...

  6. 【剑指Offer】二叉树中和为某一值的路径 解题报告(Python)

    [剑指Offer]二叉树中和为某一值的路径 解题报告(Python) 标签(空格分隔): 剑指Offer 题目地址:https://www.nowcoder.com/ta/coding-intervi ...

  7. 【剑指offer】二叉树中和为某一值的路径,C++实现

    原创文章,转载请注明出处! 博客文章索引地址 1.题目 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径由结点和有向边组成,从根结点到叶节点. // 二叉树结点的定义 st ...

  8. 【剑指Offer】面试题34. 二叉树中和为某一值的路径

    题目 输入一棵二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径.从树的根节点开始往下一直到叶节点所经过的节点形成一条路径. 示例: 给定如下二叉树,以及目标和 sum = 22, 5 / ...

  9. 《剑指offer》面试题34. 二叉树中和为某一值的路径

    问题描述 输入一棵二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径.从树的根节点开始往下一直到叶节点所经过的节点形成一条路径. 示例: 给定如下二叉树,以及目标和 sum = 22, 5 ...

  10. 【剑指offer】二叉树中和为某一值的路径

    转载请注明出处:http://blog.csdn.net/ns_code/article/details/26141815 题目描写叙述: 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数 ...

随机推荐

  1. C#文件下载流程

    private bool DownloadPicture(string picUrl, string savePath, int timeOut)         {             bool ...

  2. 使用 OpenSSL 为 Nginx 创建自签名证书 并开启客户端身份验证

    本文章默认读者了解Openssl,CA,网站证书相关知识,直接实战!配置完成后,浏览器会显示"安全的HTTPS"连接.不会像其他文章那样,是红色警告的证书提示. 准备环境 笔者使用 ...

  3. 微信公众号接入服务器验证(Go实现)

    1 基本流程 将token.timestamp.nonce三个参数进行字典序排序 将三个参数字符串拼接成一个字符串进行sha1加密 开发者获得加密后的字符串可与signature对比,标识该请求来源于 ...

  4. java并发编程(二十三)----(JUC集合)ConcurrentSkipListMap介绍

    ConcurrentSkipListMap提供了一种线程安全的并发访问的排序映射表.内部是SkipList(跳表)结构实现,在理论上能够在O(log(n))时间内完成查找.插入.删除操作. 理解Ski ...

  5. 2019牛客多校训练第三场B.Crazy Binary String(思维+前缀和)

    题目传送门 大致题意: 输入整数n(1<=n<=100000),再输入由n个0或1组成的字符串,求该字符串中满足1和0个数相等的最长子串.子序列. sample input: 801001 ...

  6. Flink 源码解析 —— 如何获取 ExecutionGraph ?

    https://t.zsxq.com/UnA2jIi 博客 1.Flink 从0到1学习 -- Apache Flink 介绍 2.Flink 从0到1学习 -- Mac 上搭建 Flink 1.6. ...

  7. intellIJ IDEA学习笔记2

    常用的有fori/sout/psvm+Tab即可生成循环.System.out.main方法等boilerplate样板代码 例如要输入for(User user : users)只需输入user.f ...

  8. 全世界仅有的唯一最高LINUX版本的白菜路由,支持NAND记

    在上上篇 真千兆路由的极限之OPENWRT MAKE, 某品牌白菜价QCA9558/QCA9880/QCA8337N纯种组合OS搭建时记 里,有没有还记否之模式退一步,海阔天空 回到了远古时代的ar7 ...

  9. EXP查询合集提权后渗透必备

    0x00 整理的一些后渗透提权需要用到的一些漏洞,后渗透提权的时候可以看一下目标机那些补丁没打,再进行下一步渗透提权. 0x01 CVE-2019-0803 [An elevation of priv ...

  10. sea.js的同步魔法

    前些时间也是想写点关于CMD模块规范的文字,以便帮助自己理解.今天看到一篇知乎回答,算是给了我一点启发. 同步写法却不阻塞? 先上一个sea.js很经典的模块写法: // 定义一个模块 define( ...