《xzc最喜欢的二叉树》 部分数据标程 Apare_xzc

2023-10-21 02:40

本文主要是介绍《xzc最喜欢的二叉树》 部分数据标程 Apare_xzc,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《xzc最喜欢的二叉树》 部分数据&标程


题目链接:xzc最喜欢的二叉树


大致展示

输入先序遍历和中序遍历,还原二叉树,并得到后续遍历,求叶子节点的个数,树的最大深度
输入保证每个节点的值各不相同

输入的先序遍历为:ABDHIORSEJKCFLPQTUGMN
输入的中序遍历为:HDIROSBJEKAFPLTUQCMGN

先序遍历如下:A B D H I O R S E J K C F L P Q T U G M N
中序遍历如下:H D I R O S B J E K A F P L T U Q C M G N
后序遍历如下:H R S O I D J K E B P U T Q L F M N G C A

节点4(H)是叶子节点
节点7®是叶子节点
节点8(S)是叶子节点
节点10(J)是叶子节点
节点11(K)是叶子节点
节点15§是叶子节点
节点18(U)是叶子节点
节点20(M)是叶子节点
节点21(N)是叶子节点
这棵树有9个叶子节点

这棵树一共有7层,最深的一层在先序遍历中的第一个节点是:18(U)

请按任意键继续. . .


Sample Input

3
3
ABC
BAC
8
ABDFCEGH
BFDACGEH
21
ABDHIORSEJKCFLPQTUGMN
HDIROSBJEKAFPLTUQCMGN

Sample Output

Case #1:
该二叉树的后序遍历为:BCA
该二叉树的叶子节点个数为:2
该二叉树的层数为:2,最深的叶子节点的值为:BCase #2:
该二叉树的后序遍历为:FDBGHECA
该二叉树的叶子节点个数为:3
该二叉树的层数为:4,最深的叶子节点的值为:FCase #3:
该二叉树的后序遍历为:HRSOIDJKEBPUTQLFMNGCA
该二叉树的叶子节点个数为:9
该二叉树的层数为:7,最深的叶子节点的值为:U

标程std.cpp

/*
FileName: std.cpp 
Author: xzc
Date: 2020.1.27 
*/
#include <bits/stdc++.h>
using namespace std;
const int maxn = 105;
const int maxm = 100+10;
char InOrder[maxn],PreOrder[maxn]; //输入的中序遍历和先序遍历 
int Lchild[maxn],Rchild[maxn],fa[maxn],n,cnt; //记录每个节点的左子节点编号,右子节点编号,父节点编号 
map<char,int> pos; 
void dfs();
void getPostOrder(int);
void CountLeaves(int,int&);
void getMaxDeep(int,int,int&,int&);
int main()
{
//	freopen("in.txt","r",stdin);
//	freopen("StdOut.txt","w",stdout); int T;scanf("%d",&T);for(int ca=1; ca<=T; ++ca){if(ca>1) printf("\n");pos.clear();scanf("%d",&n); //以连续字符串的形式读入先序遍历和中序遍历 scanf("%s",PreOrder+1);scanf("%s",InOrder+1);//初始化每个节点左右子节点均为空 memset(Lchild,-1,sizeof(Lchild));memset(Rchild,-1,sizeof(Rchild));fa[1] = 1;for(int i=1;i<=n;++i){   //预处理 pos是一个map:作用:将 pos[InOrder[i]] = i;}cnt = 1; //dfs初始化,先序遍历的第一个节点一定是根节点 dfs(); //得到每个节点Lchild,Rchild和fa的信息 //后序遍历 printf("Case #%d:\n",ca);cout<<"该二叉树的后序遍历为:"; getPostOrder(1);printf("\n"); //统计二叉树叶子节点的个数 int cntOfLeaves = 0;CountLeaves(1,cntOfLeaves);printf("该二叉树的叶子节点个数为:%d\n",cntOfLeaves);//求树的层数(最大深度)以及最深的节点 int MaxDeep = 0, MaxDeepLeafID = 0;getMaxDeep(1,1,MaxDeep,MaxDeepLeafID);printf("该二叉树的层数为:%d,最深的叶子节点的值为:%c\n",MaxDeep,PreOrder[MaxDeepLeafID]);} fclose(stdin);fclose(stdout);	return 0;	
} void dfs() //先序遍历中的序号 
{if(cnt==n) return;  //cnt = fa 表示上一个节点 int val = PreOrder[cnt]; //值 int p = pos[val];  //在中序遍历中的位置 int NextVal = PreOrder[cnt+1];int Nextp = pos[NextVal];if(Nextp<p) //cnt+1是cnt的左子节点 {Lchild[cnt] = cnt+1;fa[cnt+1] = cnt;}	else //Nextp > p   //可能该节点是某个节点的右子节点 {int father = -1;int x = cnt; //上一个节点while(true)  //先序遍历的第一个结点必定是树的根节点 {if(Rchild[x]==-1&&Nextp>pos[PreOrder[x]]){father = x;	} if(x==1) break;x = fa[x];	} Rchild[father] = cnt+1;fa[cnt+1] = father;}cnt++;if(cnt==n) return;dfs();
}void getPostOrder(int x)
{if(Lchild[x]!=-1) getPostOrder(Lchild[x]);if(Rchild[x]!=-1) getPostOrder(Rchild[x]);cout<<PreOrder[x];
}void CountLeaves(int x,int& num)
{if(Lchild[x]==-1&&Rchild[x]==-1) num++;if(Lchild[x]!=-1) CountLeaves(Lchild[x],num);if(Rchild[x]!=-1) CountLeaves(Rchild[x],num);
}
void getMaxDeep(int x,int deep,int &ans,int &LeafID)
{if(deep>ans){ans = deep;LeafID = x;}if(Lchild[x]!=-1) getMaxDeep(Lchild[x],deep+1,ans,LeafID);if(Rchild[x]!=-1) getMaxDeep(Rchild[x],deep+1,ans,LeafID); 
}


在这里插入图片描述

这篇关于《xzc最喜欢的二叉树》 部分数据标程 Apare_xzc的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元

Linux lvm实例之如何创建一个专用于MySQL数据存储的LVM卷组

《Linuxlvm实例之如何创建一个专用于MySQL数据存储的LVM卷组》:本文主要介绍使用Linux创建一个专用于MySQL数据存储的LVM卷组的实例,具有很好的参考价值,希望对大家有所帮助,... 目录在Centos 7上创建卷China编程组并配置mysql数据目录1. 检查现有磁盘2. 创建物理卷3. 创

Nacos日志与Raft的数据清理指南

《Nacos日志与Raft的数据清理指南》随着运行时间的增长,Nacos的日志文件(logs/)和Raft持久化数据(data/protocol/raft/)可能会占用大量磁盘空间,影响系统稳定性,本... 目录引言1. Nacos 日志文件(logs/ 目录)清理1.1 日志文件的作用1.2 是否可以删除

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp

Python Pandas高效处理Excel数据完整指南

《PythonPandas高效处理Excel数据完整指南》在数据驱动的时代,Excel仍是大量企业存储核心数据的工具,Python的Pandas库凭借其向量化计算、内存优化和丰富的数据处理接口,成为... 目录一、环境搭建与数据读取1.1 基础环境配置1.2 数据高效载入技巧二、数据清洗核心战术2.1 缺失

Python处理超大规模数据的4大方法详解

《Python处理超大规模数据的4大方法详解》在数据的奇妙世界里,数据量就像滚雪球一样,越变越大,从最初的GB级别的小数据堆,逐渐演变成TB级别的数据大山,所以本文我们就来看看Python处理... 目录1. Mars:数据处理界的 “变形金刚”2. Dask:分布式计算的 “指挥家”3. CuPy:GPU

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue