当前位置: 首页 > news >正文

letcode::根据二叉树创建字符串

根据二叉树创建字符串

题目描述:

给你二叉树的根节点 root ,请你采用前序遍历的方式,将二叉树转化为一个由括号和整数组成的字符串,返回构造出的字符串。
空节点使用一对空括号对 “()” 表示,转化后需要省略所有不影响字符串与原始二叉树之间的一对一映射关系的空括号对。

在这里插入图片描述
在这里插入图片描述


思路:
前序遍历,从树中取出元素组成数组。
根据题意如果节点为空,用括号表示:

  1. 左边为空,右边不为空,左括号保留
  2. 左边为空,右边为空,左右括号都不保留
  3. 左边不为空,右边为空,右边括号不保留

代码:

class Solution {
public:string tree2str(TreeNode* root) {if (root == nullptr){return "";}string str = to_string(root->val);if (root->left || root->right)//能走到root->right这一步,说明左节点为空。若右节点不为空,需要打印(){str += '(';str += tree2str(root->left);str += ')';}if (root->right){str += '(';str += tree2str(root->right);str += ')';}return str;}
};
http://www.lryc.cn/news/323738.html

相关文章:

  • 6个免费的ChatGPT网站
  • 每天几道面试题|Kafka(一)基础概念
  • PLC与智能制造——蛋糕增大?谁来先行?
  • 基于spring boot框架的发艺美发店管理系统
  • Linux - IO
  • Cmake和opencv环境安装
  • Redis是如何避免“数组+链表”的过长问题
  • Grass手机注册使用教程,利用闲置手机WiFi带宽赚钱
  • java NIO群聊系统
  • ZCC5429 异步升压芯片
  • 复试专业前沿问题问答合集10-1——区块链与加密货币
  • redis【面试题】
  • linux下使用 tar 来压缩和解压 tar.gz 和 tar.xz 文件
  • Python环境下基于1D-CNN的轴承故障诊断及TSNE特征可视化
  • 进程的调度,原则,算法
  • 瑞_23种设计模式_状态模式
  • system Verilog:clocking中定义信号为input和output的区别
  • JAVA_Tomcat
  • uniapp运行项目到微信小程序报错——未找到[“sitemapLocation“]
  • pytorch升级打怪(八)
  • 全智能深度演进,一键成片让视频创作颠覆式提效
  • uniapp(vue3) H5页面连接打印机并打印
  • Android视角看鸿蒙第八课(module.json5中的各字段含义之abilities)下
  • 设计模式 适配器模式
  • 前端面试题详解
  • 抖音,剪映,TikTok,竖屏短视频转场pr模板视频素材
  • python网络相册设计与实现flask-django-nodejs-php
  • 设计模式: 外观模式
  • Samba局域网共享文件
  • 基于FPGA实现的UDP协议栈设计_汇总