1364:二叉树遍历(flist)

【算法分析】

递归 构造子树的中序遍历序列和层次遍历序列

层次遍历序列第一个元素,一定是整棵树的根结点。在中序遍历序列中找到该根结点元素,其左边就是左子树的中序遍历序列,右边就是右子树的中序遍历序列。接下来我们需要构造左右子树的层次遍历序列。

【参考代码】

复制代码
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
string in,level;//int中序遍历 level层序遍历
void preorder(int l1,int r1,int l2,int r2){
	int pos;
	for(int i=l2;i<=r2;i++){
		int flag=0;
		for(int j=l1;j<=r1;j++){
			if(level[i]==in[j]){//找根
				cout<<in[j];
				pos=j;
				flag=1;
				break;
			}
		}
		if(flag) break;
	}
	if(pos>l1) preorder(l1,pos-1,l2,r2);
	if(pos<r1) preorder(pos+1,r1,l2,r2);
}
int main()
{
	cin>>in>>level;
	preorder(0,in.length()-1,0,level.length()-1);	
    return 0;
}
相关推荐
陌路2014 分钟前
C++高级进阶--夯实进阶基础(1)
开发语言·c++
Love_云宝儿1 小时前
WKT数据示例并与GeoJSON数据对比
数据结构·gis
风筝在晴天搁浅1 小时前
快手 CodeTop LeetCode 224.基本计算器
数据结构·算法·leetcode
郝学胜-神的一滴2 小时前
中级OpenGL教程 008:精准控制高光光斑大小与强度
c++·unity·godot·three.js·图形学·opengl·unreal
牢姐与蒯2 小时前
c++数据结构之c++11(一)
数据结构·c++
iiiiyu2 小时前
IO流(二)
java·开发语言·数据结构·编程语言
折戟不必沉沙2 小时前
构造和析构函数能否是虚函数?能否调用虚函数?
c++
-To be number.wan3 小时前
算法日记 | STL- sort排序
c++·算法
不想写代码的星星3 小时前
编译期策略模式:当模板成为策略容器
c++
啦啦啦啦啦zzzz3 小时前
数据结构:平衡二叉树
数据结构·c++·二叉树