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;
    }
相关推荐
lifallen10 分钟前
Paimon vs. HBase:全链路开销对比
java·大数据·数据结构·数据库·算法·flink·hbase
liujing102329291 小时前
Day04_刷题niuke20250703
java·开发语言·算法
2401_881244402 小时前
Treap树
数据结构·算法
乌萨奇也要立志学C++2 小时前
二叉树OJ题(单值树、相同树、找子树、构建和遍历)
数据结构·算法
网安INF2 小时前
深度学习中的逻辑回归:从原理到Python实现
人工智能·python·深度学习·算法·逻辑回归
wsxqaz2 小时前
浏览器原生控件上传PDF导致hash值不同
算法·pdf·哈希算法
NAGNIP2 小时前
Transformer注意力机制——MHA&MQA&GQA
人工智能·算法
摘星编程2 小时前
多模态AI Agent技术栈解析:视觉-语言-决策融合的算法原理与实践
人工智能·算法·多模态ai·视觉语言融合·ai决策算法
NAGNIP2 小时前
一文搞懂KV-Cache
人工智能·算法
CoovallyAIHub2 小时前
RTMPose:重新定义多人姿态估计的“实时”标准!
深度学习·算法·计算机视觉