1366:二叉树输出(btout)

#include<bits/stdc++.h>
using namespace std;
struct Node
{
	char val;
	int left, right;
	int length;
};
Node node[100];
int p;
char pre_s[100], mid_s[100];
int createTree(int pl, int pr, int ml, int mr)
{
    if(pl > pr || ml > mr)
        return 0;
    int np = ++p, i;
    node[np].val = pre_s[pl];
    for(i = ml; i <= mr; ++i)
        if(mid_s[i] == pre_s[pl])
            break;
    node[np].left = createTree(pl + 1, pl + i - ml, ml, i - 1);
    node[np].right = createTree(pl + i - ml + 1, pr, i + 1, mr);
    return np;
}
int calcLen(int r)
{
	if(r == 0)
		return 0;
	else if(node[r].left == 0 && node[r].right == 0)
		return node[r].length = 1;
	else
		return node[r].length = calcLen(node[r].left) + calcLen(node[r].right);
}
void preOrder(int r) 
{
	if(r == 0)
		return;
	for(int i = 0; i < node[r].length; ++i)
		cout << node[r].val;
	cout << endl;
	preOrder(node[r].left);
	preOrder(node[r].right);
}
int main()
{
	cin >> pre_s >> mid_s;	
	int len = strlen(pre_s);
	int root = createTree(0, len - 1, 0, len - 1);
	calcLen(root);
	preOrder(root);
    return 0;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值