括号字符串表示法建立二叉树

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#define MAXSIZE 100//最大节点数
using namespace std;


typedef struct BiTnode{
	char data;
	struct BiTnode * lchild, * rchild;
}BiTnode, * BiTree;

//二叉树的建立
BiTnode* CreateBTree(char* str) {
	BiTnode* St[100], * p=NULL, * b;//st作为顺序栈,保存双亲结点
	int top = -1, k, j = 0;//top为栈顶指针
	char ch;
	b = NULL;//初始时二叉链表为空
	ch = str[j];
	while (ch != '\0')//循环处理,直到str中的每个字符扫描完毕
	{
		switch (ch)
		{
		case '(':top++; St[top] = p; k = 1; break;//开始处理左孩子结点
		case ')':top--; break;//双亲结点的子树处理完毕
		case',':k = 2; break;//处理右孩子结点
		default://遇到数据时创建新结点
			p = (BiTnode*)malloc(sizeof(BiTnode));
			p->data = ch;
			p->lchild = p->rchild = NULL;
			if (b == NULL)//尚未设置根节点
			{
				b = p;
			}
			else
			{
				switch (k)//新建结点和栈顶双亲结点的关系
				{
				case 1:St[top]->lchild = p; break;
				case 2:St[top]->rchild = p; break;
				}
			}
		}
		j++;
		ch = str[j];
	}

	return b;
}

void visit(BiTree t) {
	
		cout << t->data << ' ';

}

int PreOrderTraverse(BiTree t) {
	if (t==NULL)
	{
		return 0;
	}
	else
	{
		visit(t);
		PreOrderTraverse(t->lchild);
		PreOrderTraverse(t->rchild);
		return 1;
	}


}

int InOrderTraverse(BiTree t) {
	if (t == NULL)
	{
		return 0;
	}
	else
	{
		InOrderTraverse(t->lchild);
		visit(t);
		InOrderTraverse(t->rchild);
		return 1;
	}


}


int PostOrderTraverse(BiTree t) {
	if (t == NULL)
	{
		return 0;
	}
	else
	{
		PostOrderTraverse(t->lchild);
	
		PostOrderTraverse(t->rchild);
		visit(t);
		return 1;
	}


}


int main() {
	char str[100] = { '\0' };
	while (cin >> str) {

		BiTree t = CreateBTree(str);
		PostOrderTraverse(t);
		cout << endl;
	}
	return 0;
}

括号字符串表示法是一种用括号来表示二叉树结构的方法。在这种表示法中,每个节点都由一对括号包围,并且子树之间以逗号分隔。具体地说,左括号表示子树的开始,右括号表示子树的结束,逗号表示左右子树之间的分隔。

例如,下面的括号字符串 (A,(B,(D),(E)),(C,(F),())) 表示的二叉树如下图所示:

 

我们可以根据括号字符串建立二叉树的过程如下:

  1. 首先创建一个根节点,并将其入栈。
  2. 从左到右遍历括号字符串,每当遇到一个字符时,如果其为左括号,则说明它是当前节点的左子节点,需要新建一个节点,并将其入栈;如果其为逗号,则跳过;如果其为右括号,则说明当前节点的左右子树已经遍历完毕,需要将其出栈,回到其父节点继续遍历。
  3. 遍历结束后,栈顶元素即为根节点。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

湿物男

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值