数据结构实验之二叉树四:(先序中序)还原二叉树 (SDUT 3343)
2024-09-27 16:22:14
#include <bits/stdc++.h>
using namespace std;
struct node
{
char data;
struct node *lc, *rc;
};
char a[100],b[100];
int n;
struct node *creat(int len, char a[], char b[])
{
if(len == 0) return NULL;
int i;
struct node *root;
root = new node;
root -> data = a[0];
for(i = 0; i < len; i ++)
{
if(a[0] == b[i])
{
break;
}
}
root -> lc = creat(i, a + 1, b);
root -> rc = creat(len - i - 1,a + i + 1, b + i + 1);
return root;
};
int fin(struct node *root)
{
// cout << "yes" << endl;
int d1, d2;
int h = 0;
if(root)
{
d1 = fin(root -> lc);
d2 = fin(root -> rc);
h = max(d1+1,d2+ 1);
}
return h;
}
int main()
{
while(~scanf("%d",&n))
{
scanf("%s %s", a,b);
struct node *root;
root = creat(n,a,b);
int ans = fin(root);
printf("%d\n",ans);
}
return 0;
}
最新文章
- Ubuntu 14.04 更新源
- Mvc多级Views目录 asp.net mvc4 路由重写及 修改view 的寻找视图的规则
- [转]jquery 点击表格变为input可以修改无刷新更新数据
- 匿名函数:Lambda表达式和匿名方法
- [麦先生]LINUX常用命令总结
- BZOJ4013 : [HNOI2015]实验比较
- poj 3045 Cow Acrobats(二分搜索?)
- jQuery代码不能执行,必须在代码之前就要包含jQuery包
- javascript第六课类型转换
- Web API实现POST报文的构造与推送
- Camera Path插件的使用
- H5移动端开发入门知识以及CSS的单位汇总与用法
- buffer_pool.go
- 20175315 实验二《Java面向对象程序设计》实验报告
- axios拦截器
- Cherry.chen window.clipboardData实现剪切板操作总结 (好像只有ie好用)
- Windows下VMware14黑屏
- 洛谷P3185 分裂游戏
- a标签响应onclick事件,并且不执行href动作
- ActiveMQ之HelloWorld