二叉树路径与回溯法

前言

算法是计算机软件的基础,常见算法是软件开发的核心基本功,今年打算深入学习一些算法,记录一些算法理论以及最佳实践,希望可以坚持下去,关注我,我们一起学习,增强我们的基本功。

二叉树的路径

leetcode第257题需要查找二叉树的所有路径。

二叉树的路径就是根节点到每个叶子节点之间的路径。

我们只要使用前序遍历,每次遍历到叶子节点的时候收集一次路径,直到遍历到最后一个叶子节点,所有路径都可以收集完成。

比如下方二叉树,总共有3条路径

路径1: 8 5 3

路径2: 8 5 6,我们可以发现求路径2的时候,我们只要回到5这个节点,再遍历右节点6就可以得到路径2,这就是回溯的过程。

路径3: 8 9, 我们可以发现求路径3的时候,我们只要回到8这个节点,再遍历右节点9就可以得到路径3,这也是回溯的过程。

编码求二叉树的路径

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    List<String> result = new ArrayList<>();
    public List<String> binaryTreePaths(TreeNode root) {
        List<Integer> subResult = new ArrayList<>();
        binaryTreePaths2(root, subResult);
        return result;
    }

    //递归和回溯求解二叉树路径
    public void  binaryTreePaths2(TreeNode root, List<Integer> subResult) {
        //前序遍历,按中左右顺序遍历
        subResult.add(root.val);
        if(root.left == null && root.right == null) {
            String r = "";
            for(int i=0; i<subResult.size(); i++) {
                if(i>0) {
                    r = r + "->" + subResult.get(i);
                } else {
                    r += subResult.get(i);
                }
               
            }
            result.add(r);
            return;
        }
        //遍历左子树
        if(root.left != null) {
            binaryTreePaths2(root.left, subResult);
            //这里其实就是回溯
            subResult.remove(subResult.size()-1);
        }
        //遍历右子树
        if(root.right != null) {
            binaryTreePaths2(root.right, subResult);
            //这里其实就是回溯
            subResult.remove(subResult.size()-1);
        }

    }
}

总结

看完今天的题目,发现回溯和递归是一起出现的。回溯是回退部分递归走过的路径,再接着继续遍历其他节点。

看完上面的代码,再看看这张图,是不是更好理解回溯了。

嘿,既然看到这里了,关注我们,一起学习技术,一起变强。

相关推荐
Frostnova丶2 分钟前
LeetCode 67. 二进制求和
算法·leetcode
上海锟联科技13 分钟前
DAS 与 FBG 振动监测对比:工程应用中该如何选择?
数据结构·算法·分布式光纤传感
星火开发设计13 分钟前
模板参数:类型参数与非类型参数的区别
java·开发语言·前端·数据库·c++·算法
JialBro23 分钟前
【嵌入式】直流无刷电机FOC控制算法全解析
算法·嵌入式·直流·foc·新手·控制算法·无刷电机
昌兵鼠鼠23 分钟前
LeetCode Hot100 哈希
学习·算法·leetcode·哈希算法
忘梓.24 分钟前
二叉搜索树·极速分拣篇」:用C++怒肝《双截棍》分拣算法,暴打节点删除Boss战!
开发语言·c++·算法
人工智能AI酱24 分钟前
【AI深究】高斯混合模型(GMM)全网最详细全流程详解与案例(附Python代码演示) | 混合模型概率密度函数、多元高斯分布概率密度函数、期望最大化(EM)算法 | 实际案例与流程 | 优、缺点分析
人工智能·python·算法·机器学习·分类·回归·聚类
Aileen_0v025 分钟前
【数据结构中链表常用的方法实现过程】
java·开发语言·数据结构·算法·链表·动态规划·csdn开发云
逻辑流25 分钟前
《精准测量的起点:STM32中的电压电流有效值计算算法》
stm32·单片机·嵌入式硬件·算法
脏脏a26 分钟前
【优选算法・双指针】以 O (n) 复杂度重构数组操作:从暴力遍历到线性高效的范式跃迁
算法·leetcode·双指针·牛客·优选算法