news 2026/3/23 21:41:33

【例3-5】扩展二叉树(信息学奥赛一本通- P1340)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【例3-5】扩展二叉树(信息学奥赛一本通- P1340)

【题目描述】

由于先序、中序和后序序列中的任一个都不能唯一确定一棵二叉树,所以对二叉树做如下处理,将二叉树的空结点用·补齐,如图所示。我们把这样处理后的二叉树称为原二叉树的扩展二叉树,扩展二叉树的先序和后序序列能唯一确定其二叉树。

现给出扩展二叉树的先序序列,要求输出其中序和后序序列。

【输入】

扩展二叉树的先序序列。

【输出】

输出其中序和后序序列。

【输入样例】

ABD..EF..G..C..

【输出样例】

DBFEGAC DFGEBCA
/* //先建树 顺序存储 #include <bits/stdc++.h> using namespace std; string a; struct node{ int l; int r; char data; node(){ l=r=0; } }tre[2000]; int ind=-1;//记录读取到a数组哪一个数 void midorder(int root){//中序遍历 if(tre[root].l!=0) midorder(root*2); if(tre[root].data!='.') cout<<tre[root].data; if(tre[root].r!=0) midorder(root*2+1); } void postorder(int root){//后序遍历 if(tre[root].l!=0) postorder(root*2); if(tre[root].r!=0) postorder(root*2+1); if(tre[root].data!='.') cout<<tre[root].data; } void build(int k){ ind++; if(ind>=a.size()) return; if(a[ind]=='.'){ tre[k].data='.'; return; } else{ tre[k].data=a[ind]; tre[k].l=k*2; build(k*2); tre[k].r=k*2+1; build(k*2+1); } } int main(){ cin>>a; build(1); midorder(1); cout<<endl; postorder(1); } */ //先建树 然后链式存储 #include <bits/stdc++.h> using namespace std; string a; struct node{ int l; int r; char data; node(){ l=r=0; } }tre[2000]; int ind=-1;//记录读取到a数组哪一个数 int ind2=1; void midorder(int root){//中序遍历 if(tre[root].l!=0) midorder(tre[root].l); if(tre[root].data!='.') cout<<tre[root].data; if(tre[root].r!=0) midorder(tre[root].r); } void postorder(int root){//后序遍历 if(tre[root].l!=0) postorder(tre[root].l); if(tre[root].r!=0) postorder(tre[root].r); if(tre[root].data!='.') cout<<tre[root].data; } void build(int k){ ind++; if(ind>=a.size()) return; if(a[ind]=='.'){ tre[k].data='.'; return; } else{ tre[k].data=a[ind]; tre[k].l=++ind2; build(ind2); tre[k].r=++ind2; build(ind2); } } int main(){ cin>>a; build(1); midorder(1); cout<<endl; postorder(1); }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/20 8:10:35

基于遗传算法的33节点配电网网络重构MATLAB实现

1. 主程序文件 % 33节点配电网网络重构 - 遗传算法优化 clear; clc; close all;%% 参数设置 pop_size 50; % 种群大小 max_gen 100; % 最大迭代次数 pc 0.8; % 交叉概率 pm 0.1; % 变异概率 elite_rate 0.1; % 精英保…

作者头像 李华
网站建设 2026/3/16 18:13:26

Graph Unlearning---论文总结

一、研究背景 1、隐私法规与被遗忘权 近年来&#xff0c;随着《通用数据保护条例》&#xff08;GDPR&#xff09;、《加州消费者隐私法案》&#xff08;CCPA&#xff09;等法律法规的颁布&#xff0c;数据隐私保护成为了全球关注的焦点。其中最重要且最具争议的条款之一是 “…

作者头像 李华
网站建设 2026/3/22 12:52:04

Aave V4:从割裂市场到模块化流动性

撰文&#xff1a;Tia&#xff0c;Techub News 在 DeFi 借贷领域&#xff0c;Aave 一直是创新与行业标准的风向标。随着用户规模和资产种类的增长&#xff0c;Aave V3 逐渐暴露出流动性割裂、风险管理和清算机制相对粗糙的问题。为应对这些挑战&#xff0c;Aave V4 进行了系统性…

作者头像 李华
网站建设 2026/3/15 8:25:58

Kali_2025年最新版下载安装最全流程功能介绍(内附安装教程)

收藏必备&#xff01;零基础也能学会的Kali Linux安装与使用指南&#xff0c;网络安全学习首选系统 文章主要介绍了Kali Linux这一基于Debian的安全专用操作系统&#xff0c;包含其特点(开源免费、支持无线注入、高度可定制等)、适用人群(渗透测试者、安全研究员等)以及安装步…

作者头像 李华
网站建设 2026/3/17 21:47:16

详谈:解释器模式(三)

我们接上文来继续讲&#xff1a;计算符怎么处理呢&#xff1f;计算符左右两边可能是单个数字&#xff0c;也可能是另一个计算公式。但无论是数字还是公式&#xff0c;两者都有一个共同点&#xff0c;那就是他们都会返回一个整数&#xff1a;数字返回其本身&#xff0c;公式返回…

作者头像 李华