【HBU数据结构月考】7-2 还原二叉树 (30 分) 输出高度

2023-12-04 18:48

本文主要是介绍【HBU数据结构月考】7-2 还原二叉树 (30 分) 输出高度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

7-2 还原二叉树 (30 分)

给定一棵二叉树的先序遍历序列和中序遍历序列,要求计算该二叉树的高度。

输入格式:

输入首先给出正整数N(≤50),为树中结点总数。下面两行先后给出先序和中序遍历序列,均是长度为N的不包含重复英文字母(区别大小写)的字符串。

输出格式:

输出为一个整数,即该二叉树的高度。

输入样例:

9
ABDFGHIEC
FDHGIBEAC

输出样例:

5

 输出高度,两个函数一个生成树,一个判断树的深度。就行了

函数1:生成树

申请内存,然后存数据,递归连成树。

背下来,背下来,背下来!!!!

Tree* creat(int root,int beg ,int len){
    Tree * T;
    int i;
    if(len<=0) T=NULL;
    else{
        T=(struct Tree*)malloc(sizeof(Tree));
        T->data=v1[root];
    for(i=0;v1[root]!=v2[beg+i];i++);
    T->left=creat(root+1,beg,i);
    T->right=creat(root+i+1,beg+i+1,len-i-1);
    }return T;
}

函数2:判断树的深度

递归去求深度。背下来,背下来,背下来!!!!!!

int getHight(Tree* T){
    if(T){
        int m=getHight(T->left);
        int n=getHight(T->right);
        if(m<n)return n+1;
        return m+1;
    }return 0;
}

#include<iostream>
using namespace std;
struct Tree{char data;struct Tree *left,*right;
};
char v1[100000];
char v2[100000];
Tree* creat(int root,int beg ,int len){Tree * T;int i;if(len<=0) T=NULL;else{T=(struct Tree*)malloc(sizeof(Tree));T->data=v1[root];for(i=0;v1[root]!=v2[beg+i];i++);T->left=creat(root+1,beg,i);T->right=creat(root+i+1,beg+i+1,len-i-1);}return T;
}
int getHight(Tree* T){if(T){int m=getHight(T->left);int n=getHight(T->right);if(m<n)return n+1;return m+1;}return 0;
}
int main(){int n;cin>>n;for(int i=0;i<n;i++)cin>>v1[i];for(int i=0;i<n;i++)cin>>v2[i];Tree * T=creat(0,0,n);cout<<getHight(T);return 0;
}

 

这篇关于【HBU数据结构月考】7-2 还原二叉树 (30 分) 输出高度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/454531

相关文章

从基础到高级详解Python数值格式化输出的完全指南

《从基础到高级详解Python数值格式化输出的完全指南》在数据分析、金融计算和科学报告领域,数值格式化是提升可读性和专业性的关键技术,本文将深入解析Python中数值格式化输出的相关方法,感兴趣的小伙... 目录引言:数值格式化的核心价值一、基础格式化方法1.1 三种核心格式化方式对比1.2 基础格式化示例

redis数据结构之String详解

《redis数据结构之String详解》Redis以String为基础类型,因C字符串效率低、非二进制安全等问题,采用SDS动态字符串实现高效存储,通过RedisObject封装,支持多种编码方式(如... 目录一、为什么Redis选String作为基础类型?二、SDS底层数据结构三、RedisObject

java -jar example.jar 产生的日志输出到指定文件的方法

《java-jarexample.jar产生的日志输出到指定文件的方法》这篇文章给大家介绍java-jarexample.jar产生的日志输出到指定文件的方法,本文给大家介绍的非常详细,对大家的... 目录怎么让 Java -jar example.jar 产生的日志输出到指定文件一、方法1:使用重定向1、

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

在Linux中改变echo输出颜色的实现方法

《在Linux中改变echo输出颜色的实现方法》在Linux系统的命令行环境下,为了使输出信息更加清晰、突出,便于用户快速识别和区分不同类型的信息,常常需要改变echo命令的输出颜色,所以本文给大家介... 目python录在linux中改变echo输出颜色的方法技术背景实现步骤使用ANSI转义码使用tpu

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

python多种数据类型输出为Excel文件

《python多种数据类型输出为Excel文件》本文主要介绍了将Python中的列表、元组、字典和集合等数据类型输出到Excel文件中,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一.列表List二.字典dict三.集合set四.元组tuplepython中的列表、元组、字典

Spring AI集成DeepSeek实现流式输出的操作方法

《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring