01.10

257.二叉树的所有路径

思路

一开始题目看错,以为是二叉树根到每个节点的路径,后来改正是到每个叶子节点路径。

深度优先搜索:二叉树所有路径,那么只需遍历其左右子树的路径列表,然后再将该节点的值放入路径即可。如果当前是叶子节点,将值加入路径;如果不是叶子节点,递归左右子树,并最后将值加入路径前端。

题解给出另外一种层序遍历,思路更简单,果然层序遍历能做很多二叉树题。

总结

与昨天做的题目有些类似,都是递归然后自底向上进行回溯,需要好好理解这个思想。

代码

java 复制代码
    public List<String> binaryTreePaths(TreeNode root) {
        List<String> list=new ArrayList<>();
        if (root==null) return list;
        List<String> result=recur(root,list);
        return result;
    }
    public List<String> recur(TreeNode root,List<String> list){
        if (root==null) return list;
        List<String> temp = new ArrayList<>(list);
        if (root.left==null && root.right==null) {
            temp.add(String.valueOf(root.val));
            return temp;
        }
        List<String> left=recur(root.left,temp);
        List<String> right=recur(root.right,temp);
        left.addAll(right);
        for (int i = 0; i < left.size(); i++) {
            String s = left.get(i);
            left.set(i,root.val+"->"+s);
        }
        return left;
    }
相关推荐
十七算法实验室8 分钟前
Matlab实现麻雀优化算法优化随机森林算法模型 (SSA-RF)(附源码)
算法·决策树·随机森林·机器学习·支持向量机·matlab·启发式算法
黑不拉几的小白兔19 分钟前
PTA部分题目C++重练
开发语言·c++·算法
迷迭所归处20 分钟前
动态规划 —— dp 问题-买卖股票的最佳时机IV
算法·动态规划
chordful42 分钟前
Leetcode热题100-32 最长有效括号
c++·算法·leetcode·动态规划
_OLi_1 小时前
力扣 LeetCode 459. 重复的子字符串(Day4:字符串)
算法·leetcode·职场和发展·kmp
Romanticroom1 小时前
计算机23级数据结构上机实验(第3-4周)
数据结构·算法
白藏y1 小时前
数据结构——归并排序
数据结构·算法·排序算法
ahadee1 小时前
蓝桥杯每日真题 - 第12天
c++·vscode·算法·蓝桥杯
zhentiya1 小时前
微积分第五版课后习题答案详解PDF电子版 赵树嫄
算法·pdf
luky!2 小时前
算法--解决熄灯问题
python·算法