Leetcode刷题详解——二叉树的所有路径

news2024/11/28 13:47:21

1. 题目链接:257. 二叉树的所有路径

2. 题目描述:

给你一个二叉树的根节点 root ,按 任意顺序 ,返回所有从根节点到叶子节点的路径。

叶子节点 是指没有子节点的节点。

示例 1:

img

输入:root = [1,2,3,null,5]
输出:["1->2->5","1->3"]

示例 2:

输入:root = [1]
输出:["1"]

提示:

  • 树中节点的数目在范围 [1, 100]
  • -100 <= Node.val <= 100

3. 算法(回溯)

3.1 算法思路:

使用深度优先遍历(DFS)求解

路径以字符串形式存储,从根节点开始遍历,每次遍历时将当前节点的值加入路径中,如果该节点为叶子节点,将路径存储到结果中。否则,将“->”加入到路径中并递归遍历该节点的左右子树

定义一个结果数组,进行递归。递归具体实现方法如下:

  1. 如果当前节点不为空,就将当前节点的值加入路径path中,否则直接返回
  2. 判断当前节点是否为叶子节点,如果是,则将当前路径加入到所有路径的存储数组paths中
  3. 否则,将当前节点的值加上”->”作为路径的分隔符,继续递归遍历当前节点的左右子节点
  4. 返回结果数组

特别地,我们可以只使用一个字符串存储每个状态的字符串,在递归回溯的过程中,需要将路径中的当前节点移除,以回到上一个节点

具体实现方法如下:

  1. 定义一个结果数组和一个路径数组
  2. 从当前节点开始递归,递归函数的参数为当前节点、结果数组和路径数组
    1. 如果当前节点为空,返回
    2. 将当前节点的值加入到路径数组中
    3. 如果当前节点为叶子节点,将路径数组中的所有元素拼接成字符串,并将该字符串存储到结果数组中
    4. 递归遍历当前节点的左子树
    5. 递归遍历当前节点的右子树
    6. 回溯,将路径数组中的最后一个元素移除,以返回到上一个节点

请添加图片描述

3.2 C++算法代码:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    vector<string> ret; // 记录结果的向量

    // 主函数,返回所有从根节点到叶子节点的路径
    vector<string> binaryTreePaths(TreeNode* root) {
        string path; // 当前路径字符串
        if (root == nullptr) return ret; // 如果根节点为空,直接返回空结果
        dfs(root, path); // 调用深度优先搜索函数
        return ret; // 返回结果向量
    }

    // 深度优先搜索函数,递归遍历二叉树
    void dfs(TreeNode* root, string path) {
        path += to_string(root->val); // 将当前节点的值添加到路径字符串中

        // 如果当前节点是叶子节点,将路径字符串添加到结果向量中
        if (root->left == nullptr && root->right == nullptr) {
            ret.push_back(path);
            return;
        }

        path += "->"; // 在路径字符串中添加箭头符号,表示继续向下遍历

        // 如果左子节点不为空,递归调用dfs函数遍历左子树
        if (root->left) dfs(root->left, path);

        // 如果右子节点不为空,递归调用dfs函数遍历右子树
        if (root->right) dfs(root->right, path);
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1166469.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

电器展示预约小程序的效果

大小电器是人们生活中必备的&#xff0c;电商经济条件下&#xff0c;很多消费者往往会通过线上购买电器&#xff0c;使得线下商家经营困难&#xff0c;但实体店依然有存在的意义&#xff0c;比如一些大件或精细电器&#xff0c;也需要亲自挑选、本地配送等。 对实体店商家来说…

云上智能驾驶三维重建优秀实践

本文重点介绍火山引擎多媒体实验室三维重建技术在动态、静态场景的以及结合先进光场重建技术的原理与实践&#xff0c;帮助大家能更好的了解和认识云上智能三维重建如何服务智能驾驶领域&#xff0c;助力行业发展。 智能驾驶技术的不断发展&#xff0c;正在改变着我们的出行方式…

【深入探究人工智能】历史、应用、技术与未来

深入探究人工智能 前言人工智能的历史人工智能的应用人工智能的技术人工智能的未来当代的人工智能产物结语&#x1f340;小结&#x1f340; &#x1f389;博客主页&#xff1a;小智_x0___0x_ &#x1f389;欢迎关注&#xff1a;&#x1f44d;点赞&#x1f64c;收藏✍️留言 &am…

第二十一章 模板

一、模板 1、模板的概念 模板就是建立通用的模具&#xff0c;大大提高复用性 例如生活中的模板 一寸照片模板&#xff1a; PPT模板&#xff1a; 模板的特点&#xff1a; 模板不可以直接使用&#xff0c;它只是一个框架 模板的通用并不是万能的 2、函数模板 C另一种编程思…

定时器和Timer

♫什么是定时器 定时器是一种计时设备&#xff0c;通过定时器可以让某段代码达到设定的时间后再执行。定时器是一个常用的组件&#xff0c;如在进行网络编程时就常用定时器来定时重发数据包、定时检测网络连接状态、定时更新缓存等操作。 ♫实现一个定时器 定时器需要有一个优先…

chat2db初步使用和体验AI

今天下载chat2db体验了下将主要功能和使用截图总结下&#xff1a; 功能&#xff1a; 1.传统客户端能使用的功能基本都有&#xff0c;并且增加了导出excel等便捷的能力。 2.报表功能&#xff1a; 可以根据查询结果进行对应报表可视化显示 3.AI解析sql 可以根据输入的汉语例如…

比如我的企业也想要申报抖音白名单进行直播招聘,该如何操作呢?

比如现在我的企业也想要申报抖音白名单进行直播招聘&#xff0c;该如何申报呢&#xff1f; 答&#xff1a;相关企业/商家在提供自身相关的招聘资质后&#xff0c;就可以进行抖音直播报白名单的申请&#xff0c;在审核通过之后就可以百分百的在抖音直播时畅聊关于自家企业的招聘…

全志XR806基于FreeRTOS的SoftAp配网实现

1.环境搭建 由于电脑上之前就有开发其他设备用的ubuntu18.06虚拟机环境&#xff0c;就在此环境基础上进行开发。基本环境搭建参考官方文档进行&#xff1a; 全志XR806开发板开发环境搭建 2.功能实现 2.1设计思路 从官方下载的SDK开发包project/example目录下有基本功能实现…

Java后端开发——JDBC组件

JDBC&#xff08;Java Database Connectivity&#xff09;是Java SE平台的一种标准API&#xff0c;它提供了一种标准的方法来访问关系型数据库&#xff0c;使得Java程序能够与各种不同的数据库进行交互&#xff0c;这篇文章我们来进行实验体验一下。 自定义JDBC连接工具类 1.编…

【快刊推荐】EI快刊盘点,仅29天录用,国人友好,接收领域广!

综合类EI • 快刊推荐 01 期刊简介 检索数据库&#xff1a;EI &Scopus &Google Scholar 版面类别&#xff1a;正刊 数据库收录年份&#xff1a;2009年 国人占比&#xff1a;47%&#xff0c;对国人友好 年发文量&#xff1a;20篇左右 02 接收领域 生物&#xff0…

使用C++的QT框架实现俄罗斯方块

今天实现一个简单的俄罗斯方块&#xff0c;网上别人写的都比较长还复杂&#xff0c;我就写了一个简单的&#xff0c;可以实现功能的俄罗斯方块&#xff0c;使用的是C语言&#xff0c;框架都可以&#xff0c;主要是逻辑思路有都可以实现 我这边实现的逻辑为两个数组包含各个动态…

“没有酒瓶”的新春礼酒,泸州老窖的颠覆性之作

执笔 | 萧 萧 编辑 | 扬 灵 没有想到&#xff0c;新春礼酒还能跳出生肖酒造型桎梏&#xff0c;开创出“没有酒瓶的白酒”。 没有想到&#xff0c;即将要发布的新品就“藏”在每一位参会者都触手可及的餐桌正中。 没有想到&#xff0c;首发定价如此“实诚”&#xff0c;加…

python爬取Web of science论文信息

一、python爬取WOS总体思路 (一)拟实现功能描述 wos里面&#xff0c;爬取论文的名称&#xff0c;作者名称&#xff0c;作者单位&#xff0c;引用数量 要求&#xff1a;英文论文、期刊无论好坏 检索关键词&#xff1a;zhejiang academy of agricultural sciences、 xianghu lab…

【并查集】93 岛屿数量

岛屿数量 题解1 DFS&#xff08;图论经典方法&#xff09;题解2 BFS(遍历&#xff08;DFS展开【顺序不同】&#xff09;)题解3 并查集&#xff08;学习理解&#xff09; 给你一个由 ‘1’&#xff08;陆地&#xff09;和 ‘0’&#xff08;水&#xff09;组成的的二维网格&…

TikTok未来展望:数字创新的下一浪潮

随着全球数字时代的蓬勃发展&#xff0c;TikTok已经成为一个巨大的现象&#xff0c;吸引了数以亿计的用户&#xff0c;尤其是年轻一代。这个短视频分享平台已经深刻影响了社交媒体、娱乐和文化。然而&#xff0c;TikTok未来的发展前景如何&#xff1f;本文将探讨TikTok的未来展…

哈希的开放定址法的实现【C++】

哈希的开放定址法的实现【C】 1 概述2 线性探测2.1 插入2.2 查找2.3 删除2.6 完整代码2.5 线性探测的优缺点 3. 二次探测 1 概述 开放定址法也叫闭散列&#xff0c;是解决哈希冲突的一种方法&#xff0c;当发生哈希冲突之后&#xff0c;如果哈希表没有被装满(正常情况哈希表不会…

饥荒联机版 Don‘t Starve Together(WinMac)最新中文学习版

《饥荒联机版》是由Klei自主开发的开放世界冒险游戏。在这个游戏中&#xff0c;玩家将扮演各种各样的人物&#xff0c;这些人物不幸来到了一个神秘的异世界。在旅行中&#xff0c;玩家会邂逅性格各异、能力独特的同伴们&#xff0c;并和他们一起生存下去并征服异世界。游戏中的…

每日一题 117. 填充每个节点的下一个右侧节点指针 II (中等,树)

BFS&#xff0c;一层层去搜索整棵树&#xff0c;然后建立next关系即可&#xff0c;下面给出的代码的空间复杂度是O(n)的O(1) 的做法&#xff0c;当构建完上一层的next关系后&#xff0c;我们就可以像链表一样从左到右访问上一层的节点&#xff0c;显然在访问的过程中&#xff0…

N-132基于springboot,vue人事管理系统

开发工具&#xff1a;IDEA 服务器&#xff1a;Tomcat9.0&#xff0c; jdk1.8 项目构建&#xff1a;maven 数据库&#xff1a;mysql5.7 系统分前后台&#xff0c;项目采用前后端分离 前端技术&#xff1a;vueelementUI 服务端技术&#xff1a;springbootmybatis-plus 本项…

自定义类型结构体(下)

目录 结构体传参结构体实现位段什么是位段位段的内存分配位段的跨平台问题总结&#xff1a; 位段的应用位段使用的注意事项** 感谢各位大佬对我的支持,如果我的文章对你有用,欢迎点击以下链接 &#x1f412;&#x1f412;&#x1f412; 个人主页 &#x1f978;&#x1f978;&a…