力扣257. 二叉树的所有路径

思路:题目需要记录从根节点开始走的路径,无疑选用前序遍历,用一个数组paths 记录走过的节点信息,遇到叶子节点就用另一个list记录下路径,回溯时删掉paths尾节点即可

java 复制代码
class Solution {
     public List<String> binaryTreePaths(TreeNode root) {

        List<String> list = new ArrayList<>(); //处理的结果
        if(root == null) {
            return list;
        }
        List<Integer> paths = new ArrayList<>(); //当前路径顺序
        func(root, paths, list);
        return list;

    }
    public void func(TreeNode root, List<Integer> paths, List<String> list) {
        //前序遍历,中
        paths.add(root.val);

        //如果是叶子节点,就记录下路径
        if(root.left==null && root.right == null) {
            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < paths.size()-1; i++) {
                sb.append(paths.get(i)).append("->");
            }
            sb.append(paths.get(paths.size()-1));
            list.add(sb.toString());
            //return;

        }
        //左,不是叶子节点就一直递归深入
        if(root.left != null) {
            func(root.left, paths, list);
            paths.remove(paths.size()-1);//结束一轮递归要回退一步

        }
        //右
        if(root.right != null) {
            func(root.right, paths, list);
            paths.remove(paths.size()-1);

        }
    }

}
相关推荐
小学生的信奥之路5 分钟前
力扣1991:找到数组的中间位置(前缀和)
数据结构·算法·leetcode·前缀和·数组
এ᭄画画的北北10 分钟前
力扣-102.二叉树的层序遍历
数据结构·算法·leetcode
ccLianLian10 分钟前
数据结构·字典树
数据结构·算法
JeffersonZU2 小时前
【数据结构】1-4算法的空间复杂度
c语言·数据结构·算法
L_cl2 小时前
【Python 算法零基础 4.排序 ① 选择排序】
数据结构·算法·排序算法
山北雨夜漫步3 小时前
机器学习 Day18 Support Vector Machine ——最优美的机器学习算法
人工智能·算法·机器学习
拼好饭和她皆失3 小时前
算法加训之最短路 上(dijkstra算法)
算法
瓦力wow5 小时前
c语言 写一个五子棋
c语言·c++·算法
X-future4265 小时前
院校机试刷题第六天:1134矩阵翻转、1052学生成绩管理、1409对称矩阵
线性代数·算法·矩阵
Codeking__6 小时前
前缀和——中心数组下标
数据结构·算法