zoukankan      html  css  js  c++  java
  • 剑指Offer-二叉树中和为某一值的路径

    题目描述

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

    思路

    回溯法

    二叉树的深度优先遍历+每次遍历均判断是否达到条件,若是则输出

    1. root入栈,跳入该子树进行寻路操作
    2. 若root的这条路径,已满足要求,则将该路径加入到result中去
    3. 对root左右子树,继续寻路
    4. root出栈,该子树访问完毕

    代码实现

    package Tree;
    
    import java.util.ArrayList;
    
    /**
     * 二叉树中和为某一值的路径
     * 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。
     * 路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。
     */
    public class Solution45 {
        private ArrayList<ArrayList<Integer>> result = new ArrayList<>();
        private ArrayList<Integer> list = new ArrayList<>();
    
        public ArrayList<ArrayList<Integer>> FindPath(TreeNode root, int target) {
            if (root == null) {
                return result;
            }
            list.add(root.val);
            target -= root.val;
            if (target == 0 && root.left == null && root.right == null) {
                result.add(new ArrayList<Integer>(list));
            }
            FindPath(root.left, target);
            FindPath(root.right, target);
            list.remove(list.size() - 1);
            return result;
        }
    
        public class TreeNode {
            int val = 0;
            TreeNode left = null;
            TreeNode right = null;
    
            public TreeNode(int val) {
                this.val = val;
    
            }
    
        }
    }
    
    
  • 相关阅读:
    Silverlight For WinEmbedded 的页面切换实现
    如何修改 MFC Dialog 窗体的类名???
    SWIFT 开发环境
    Windows 10 安装
    Microsoft Remote Tools
    WinCE 7.0 下如何获取全路径文件名的后缀?
    年终工作总结
    Win8.1 下安装 eVC++ 4.0
    何生成一个 WinCE 下文件全路径大于 MAX_PATH(260) 字节的文件路径?
    A+B Problem III
  • 原文地址:https://www.cnblogs.com/wupeixuan/p/8777539.html
Copyright © 2011-2022 走看看