力扣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);

        }
    }

}
相关推荐
apcipot_rain5 分钟前
CSP集训错题集 第八周 主题:基础图论
算法·图论
天选之女wow5 分钟前
【代码随想录算法训练营——Day57(Day56周日休息)】图论——53.寻宝
算法·图论
文火冰糖的硅基工坊17 分钟前
[人工智能-大模型-103]:模型层 - M个神经元组成的单层神经网络的本质
python·算法·机器学习
无语子yyds1 小时前
C++双指针算法例题
数据结构·c++·算法
Skrrapper1 小时前
【STL】set、multiset、unordered_set、unordered_multiset 的区别
c++·算法·哈希算法
SunnyKriSmile1 小时前
函数递归求最大值
c语言·算法·函数递归
傻啦嘿哟1 小时前
爬虫数据去重:BloomFilter算法实现指南
爬虫·算法
立志成为大牛的小牛1 小时前
数据结构——三十六、拓扑排序(王道408)
数据结构·学习·程序人生·考研·算法
绛洞花主敏明3 小时前
Go切片的赋值
c++·算法·golang
10001hours5 小时前
初阶数据结构.1.顺序表.通讯录项目(只有源码和注释)
数据结构·算法