LeetCode题练习与总结:根据二叉树创建字符串--606

一、题目描述

给你二叉树的根节点 root ,请你采用前序遍历的方式,将二叉树转化为一个由括号和整数组成的字符串,返回构造出的字符串。

空节点使用一对空括号对 "()" 表示,转化后需要省略所有不影响字符串与原始二叉树之间的一对一映射关系的空括号对。

示例 1:

输入:root = [1,2,3,4]
输出:"1(2(4))(3)"
解释:初步转化后得到 "1(2(4)())(3()())" ,但省略所有不必要的空括号对后,字符串应该是"1(2(4))(3)" 。

示例 2:

输入:root = [1,2,3,null,4]
输出:"1(2()(4))(3)"
解释:和第一个示例类似,但是无法省略第一个空括号对,否则会破坏输入与输出一一映射的关系。

提示:

  • 树中节点的数目范围是 [1, 10^4]
  • -1000 <= Node.val <= 1000

二、解题思路

  1. 如果根节点为空,直接返回空字符串。
  2. 如果根节点不为空,首先将根节点的值转换为字符串。
  3. 接下来,递归地转换左子树和右子树。对于左子树,如果它不为空,我们需要将其转换为字符串,并在其前后加上括号;如果左子树为空,但右子树不为空,我们需要添加一对空括号表示左子树。
  4. 对于右子树,如果它不为空,我们同样需要将其转换为字符串,并在其前后加上括号;如果右子树为空,我们不需要做任何操作。
  5. 将上述步骤得到的结果拼接起来,得到最终的字符串。

三、具体代码

class Solution {public String tree2str(TreeNode root) {// 如果根节点为空,返回空字符串if (root == null) {return "";}// 将根节点的值转换为字符串String result = Integer.toString(root.val);// 如果左子树和右子树都为空,直接返回根节点的值if (root.left == null && root.right == null) {return result;}// 如果左子树不为空,递归转换左子树,并在其前后加上括号if (root.left != null) {result += "(" + tree2str(root.left) + ")";} else {// 如果左子树为空但右子树不为空,添加一对空括号result += "()";}// 如果右子树不为空,递归转换右子树,并在其前后加上括号if (root.right != null) {result += "(" + tree2str(root.right) + ")";}// 返回最终结果return result;}
}

这段代码实现了题目要求的前序遍历二叉树,并将其转换为特定格式的字符串。在递归过程中,我们根据左子树和右子树的存在情况,适当地添加括号,以确保字符串与原始二叉树之间的一对一映射关系。

四、时间复杂度和空间复杂度

1. 时间复杂度
  • tree2str 函数是递归的,它会对每个节点调用一次自身。
  • 对于每个节点,我们执行的操作包括:检查节点是否为空、转换为字符串、以及可能的字符串拼接操作。
  • 字符串拼接操作的时间复杂度取决于字符串的长度。在最坏的情况下,每次拼接操作的时间复杂度是 O(n),其中 n 是拼接后字符串的长度。
  • 因为每个节点最多被访问一次,并且字符串拼接操作是线性的,所以总的时间复杂度是 O(n),其中 n 是二叉树中所有节点的数量。
2. 空间复杂度
  • 递归的深度取决于二叉树的高度,最坏情况下,二叉树可能退化成一条链,递归深度为 n,其中 n 是节点的数量。
  • 每次递归调用都会在调用栈上占用一定的空间,这个空间是常数级别的,因为只存储了当前节点的信息。
  • 除了递归栈空间,还需要考虑字符串拼接操作的空间。在最坏情况下,字符串拼接操作可能需要 O(n) 的空间,其中 n 是最终生成的字符串的长度。
  • 因此,总的空间复杂度是 O(n),其中 n 是二叉树中所有节点的数量。

五、总结知识点

  • 递归

    • 递归是一种编程技巧,它允许函数调用自身来解决问题。在这个例子中,tree2str 函数递归地遍历二叉树,并在每个节点处生成字符串。
  • 条件语句

    • if 语句用于检查特定条件是否为真,并根据条件执行不同的代码块。在代码中,它用于检查节点是否为空,以及左右子树的存在情况。
  • 字符串操作

    • Integer.toString(root.val):将整数值转换为字符串。
    • result += ...:字符串拼接操作,将字符串连接起来。
  • 类和对象

    • TreeNode 类定义了二叉树节点的结构,包括节点值 val 以及指向左右子节点的引用 left 和 right
    • Solution 类定义了 tree2str 方法,该方法接受一个 TreeNode 类型的参数。
  • 基础数据结构

    • 二叉树是一种基础的数据结构,每个节点最多有两个子节点,分别称为左子节点和右子节点。
  • 方法重载

    • TreeNode 类的构造函数使用了方法重载,提供了不同的构造方式来创建 TreeNode 对象。
  • 空指针检查

    • 在递归调用和字符串拼接之前,代码通过检查 null 来避免空指针异常。
  • 递归终止条件

    • 当递归到达叶子节点的子节点(即 null)时,递归终止,这是递归算法的一个重要部分。

以上就是解决这个问题的详细步骤,希望能够为各位提供启发和帮助。

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

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

相关文章

人工智能入门课【手写自注意力机制】

原理 自注意力&#xff08;Self-Attention&#xff09;是一种强大的机制&#xff0c;广泛应用于自然语言处理、计算机视觉等领域&#xff0c;尤其是在Transformer架构中发挥了关键作用。它的核心思想是让模型能够动态地关注输入序列中不同位置之间的关系&#xff0c;从而更好地…

gentoo 中更改$PS1

现象&#xff1a;gentoo linux Xfce桌面&#xff0c;Terminal 终端&#xff0c;当进入很深的目录时&#xff0c;终端提示符会很长&#xff0c;不方便。如下图所示&#xff1a; 故需要修改$PS1 gentoo 默认的 PS1 在 /etc/bash/bashrc .d/10-gentoo-color.bash中定义&a…

安全防护前置

就业概述 网络安全工程师/安全运维工程师/安全工程师 安全架构师/安全专员/研究院&#xff08;数学要好&#xff09; 厂商工程师&#xff08;售前/售后&#xff09; 系统集成工程师&#xff08;所有计算机知识都要会一点&#xff09; 学习目标 前言 网络安全事件 蠕虫病毒--&…

【自然语言处理(NLP)】深度学习架构:Transformer 原理及代码实现

文章目录 介绍Transformer核心组件架构图编码器&#xff08;Encoder&#xff09;解码器&#xff08;Decoder&#xff09; 优点应用代码实现导包基于位置的前馈网络残差连接后进行层规范化编码器 Block编码器解码器 Block解码器训练预测 个人主页&#xff1a;道友老李 欢迎加入社…

mysqldump+-binlog增量备份

注意&#xff1a;二进制文件删除必须使用help purge 不可用rm -f 会崩 一、概念 增量备份&#xff1a;仅备份上次备份以后变化的数据 差异备份&#xff1a;仅备份上次完全备份以后变化的数据 完全备份&#xff1a;顾名思义&#xff0c;将数据完全备份 其中&#xff0c;…

cf集合***

当周cf集合&#xff0c;我也不知道是不是当周的了&#xff0c;麻了&#xff0c;下下周争取写到e补f C. Kevin and Puzzle&#xff08;999&#xff09; 题解&#xff1a;一眼动态规划&#xff0c;但是具体这个状态应该如何传递呢&#xff1f; 关键点&#xff1a;撒谎的人不相…

大模型概述(方便不懂技术的人入门)

1 大模型的价值 LLM模型对人类的作用&#xff0c;就是一个百科全书级的助手。有多么地百科全书&#xff0c;则用参数的量来描述&#xff0c; 一般地&#xff0c;大模型的参数越多&#xff0c;则该模型越好。例如&#xff0c;GPT-3有1750亿个参数&#xff0c;GPT-4可能有超过1万…

Linux-CentOS的yum源

1、什么是yum yum是CentOS的软件仓库管理工具。 2、yum的仓库 2.1、yum的远程仓库源 2.1.1、国内仓库 国内较知名的网络源(aliyun源&#xff0c;163源&#xff0c;sohu源&#xff0c;知名大学开源镜像等) 阿里源:https://opsx.alibaba.com/mirror 网易源:http://mirrors.1…

简单易懂的倒排索引详解

文章目录 简单易懂的倒排索引详解一、引言 简单易懂的倒排索引详解二、倒排索引的基本结构三、倒排索引的构建过程四、使用示例1、Mapper函数2、Reducer函数 五、总结 简单易懂的倒排索引详解 一、引言 倒排索引是一种广泛应用于搜索引擎和大数据处理中的数据结构&#xff0c;…

Deepseek智能AI--国产之光

以下是以每个核心问题为独立章节的高质量技术博客整理&#xff0c;采用学术级论述框架并增强可视化呈现&#xff1a; 大型语言模型深度解密&#xff1a;从哲学思辨到系统工程 目录 当服务器关闭&#xff1a;AI的终极告解与技术隐喻情感计算&#xff1a;图灵测试未触及的认知深…

如何用ChatGPT批量生成seo原创文章?TXT格式文章能否批量生成!

如何用ChatGPT批量生成文章&#xff1f;这套自动化方案或许适合你 在内容创作领域&#xff0c;效率与质量的天平往往难以平衡——直到AI写作技术出现。近期观察到&#xff0c;越来越多的创作者开始借助ChatGPT等AI模型实现批量文章生成&#xff0c;但如何系统化地运用这项技术…

【回溯+剪枝】组合问题!

文章目录 77. 组合解题思路&#xff1a;回溯剪枝优化 77. 组合 77. 组合 ​ 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 ​ 你可以按 任何顺序 返回答案。 示例 1&#xff1a; 输入&#xff1a;n 4, k 2 输出&#xff1a; [[2,4],[3,…

04树 + 堆 + 优先队列 + 图(D1_树(D7_B+树(B+)))

目录 一、基本介绍 二、重要概念 非叶节点 叶节点 三、阶数 四、基本操作 等值查询(query) 范围查询(rangeQuery) 更新(update) 插入(insert) 删除(remove) 五、知识小结 一、基本介绍 B树是一种树数据结构&#xff0c;通常用于数据库和操作系统的文件系统中。 B树…

【力扣】283.移动零

AC截图 题目 思路 遍历nums数组&#xff0c;将0删除并计数&#xff0c;最后在nums数组尾部添加足量的零 有一个问题是&#xff0c;vector数组一旦erase某个元素&#xff0c;会导致迭代器失效。好在有解决办法&#xff0c;erase会返回下一个有效元素的新迭代器。 代码 class …

Games104——引擎工具链高级概念与应用

世界编辑器 其实是一个平台&#xff08;hub&#xff09;&#xff0c;集合了所有能够制作地形世界的逻辑 editor viewport&#xff1a;可以说是游戏引擎的特殊视角&#xff0c;会有部分editor only的代码&#xff08;不小心开放就会变成外挂入口&#xff09;Editable Object&…

【力扣:新动计划,编程入门 —— 题解 ③】

—— 25.1.26 231. 2 的幂 给你一个整数 n&#xff0c;请你判断该整数是否是 2 的幂次方。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 如果存在一个整数 x 使得 n 2x &#xff0c;则认为 n 是 2 的幂次方。 示例 1&#xff1a; 输入&#xff1a;…

10 Flink CDC

10 Flink CDC 1. CDC是什么2. CDC 的种类3. 传统CDC与Flink CDC对比4. Flink-CDC 案例5. Flink SQL 方式的案例 1. CDC是什么 CDC 是 Change Data Capture&#xff08;变更数据获取&#xff09;的简称。核心思想是&#xff0c;监测并捕获数据库的变动&#xff08;包括数据或数…

【PyTorch】6.张量运算函数:一键开启!PyTorch 张量函数的宝藏工厂

目录 1. 常见运算函数 个人主页&#xff1a;Icomi 专栏地址&#xff1a;PyTorch入门 在深度学习蓬勃发展的当下&#xff0c;PyTorch 是不可或缺的工具。它作为强大的深度学习框架&#xff0c;为构建和训练神经网络提供了高效且灵活的平台。神经网络作为人工智能的核心技术&…

Python-基于PyQt5,wordcloud,pillow,numpy,os,sys等的智能词云生成器

前言&#xff1a;日常生活中&#xff0c;我们有时后就会遇见这样的情形&#xff1a;我们需要将给定的数据进行可视化处理&#xff0c;同时保证呈现比较良好的量化效果。这时候我们可能就会用到词云图。词云图&#xff08;Word cloud&#xff09;又称文字云&#xff0c;是一种文…

DeepSeek-R1论文研读:通过强化学习激励LLM中的推理能力

DeepSeek在朋友圈&#xff0c;媒体&#xff0c;霸屏了好长时间&#xff0c;春节期间&#xff0c;研读一下论文算是时下的回应。论文原址&#xff1a;[2501.12948] DeepSeek-R1: Incentivizing Reasoning Capability in LLMs via Reinforcement Learning 摘要&#xff1a; 我们…