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

    /**
     * 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。
     * 路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。
     */
    package javabasic.nowcoder;
    
    import java.util.ArrayList;
    
    public class Main29 {
    
    	ArrayList<ArrayList<Integer>> listAll = new ArrayList<ArrayList<Integer>>();
    	public ArrayList<ArrayList<Integer>> FindPath(TreeNode root,int target) {
    		ArrayList<Integer> list = new ArrayList<Integer>();
    		find(root, target, list);
            return listAll;
        }
    
    	private void find(TreeNode root, int target, ArrayList<Integer> list) {
    		if(root==null||target<0) {
    			return ;
    		}
    		list.add(root.val);
    		target-=root.val;
    		if(target==0&&root.left==null&&root.right==null) {
    			listAll.add(new ArrayList<Integer>(list));
    		}
    		find(root.left,target,list);
    		find(root.right,target,list);
    		list.remove(list.size()-1);
    	}
    	public static void main(String[] args) {
    		ArrayList<Integer> list = new ArrayList<Integer>();
    		list.add(1);
    		list.add(2);
    		list.add(3);
    		list.add(4);
    		System.out.println(list);
    		System.out.println(new ArrayList<Integer>(list));
    		System.out.println("===============");
    		System.out.println(new ArrayList<Integer>(list));
    		list.remove(list.size()-1);
    		System.out.println(list);
    	}
    }
    

      

  • 相关阅读:
    文件的打开和保存
    eclipse快捷键汇总
    FileNameExtensionFilter文件过滤
    java中文件保存、打开文件对话框
    FileInputStream(字节流)与fileReader(字符流) 的区别
    Java文本编辑器中遇到的问题详解
    前端基础 之 BOM和DOM
    前端基础 之JS
    前端基础 之 CSS
    前端基础之 HTML
  • 原文地址:https://www.cnblogs.com/zhaohuan1996/p/9049971.html
Copyright © 2011-2022 走看看