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;
    }
相关推荐
Tiandaren26 分钟前
大模型应用03 || 函数调用 Function Calling || 概念、思想、流程
人工智能·算法·microsoft·数据分析
2301_795167201 小时前
玩转Rust高级应用 如何进行理解Refutability(可反驳性): 模式是否会匹配失效
开发语言·算法·rust
小当家.1051 小时前
[LeetCode]Hot100系列.贪心总结+思想总结
算法·leetcode·职场和发展
墨雪不会编程2 小时前
数据结构—排序算法篇二
数据结构·算法·排序算法
ShineWinsu2 小时前
对于数据结构:堆的超详细保姆级解析—上
数据结构·c++·算法·计算机·二叉树·顺序表·
im_AMBER2 小时前
Leetcode 46
c语言·c++·笔记·学习·算法·leetcode
努力学算法的蒟蒻3 小时前
day09(11.6)——leetcode面试经典150
算法·leetcode·职场和发展
2301_796512523 小时前
Rust编程学习 - 内存分配机制,如何动态大小类型和 `Sized` trait
学习·算法·rust
卿言卿语4 小时前
CC23-最长的连续元素序列长度
java·算法·哈希算法
天选之女wow4 小时前
【代码随想录算法训练营——Day60】图论——94.城市间货物运输I、95.城市间货物运输II、96.城市间货物运输III
android·算法·图论