二叉树的建立和遍历

先序的方法建立二叉树(链表)

typedef struct BiTNode{
    char data;
    struct BiTNode *lchild;
    struct BiTNode *rchild;
}BiTNode, *BiTree;
BiTree CreateBiTree(BiTree T){
	char ch;
	scanf("%c", &ch);
	if(ch == ' ')	  T = NULL;
	else{
		T = (BiTNode *)malloc(sizeof(BiTNode));
		T->data = ch;
		T->lchild = CreateBiTree( T->lchild);
		T->rchild = CreateBiTree( T->rchild);
	}
	return T;
}

三种顺序遍历二叉树,并且寻找相应的值,返回其所在的层数

void visit(char c, int level){
	printf("正在查找...\n");
	if(c == 'D')
	{
		printf("已经找到:\n");
		printf("%c is at %d level of BiTree\n", c, level);
	}
		
}
void PreOrderTraverse(BiTree T, int level){
	if(T){
		printf("正在先序遍历二叉树...\n");
		visit(T->data, level);
		PreOrderTraverse(T->lchild, level+1);
		PreOrderTraverse(T->rchild, level+1);
	}
}
void InOrderTraverse(BiTree T, int level){
	if(T){
		printf("正在中序遍历二叉树...\n");
		InOrderTraverse(T->lchild, level + 1);
		visit(T->data, level);
		InOrderTraverse(T->rchild, level + 1);
	}
}
void PosOrderTraverse(BiTree T, int level){
	if(T){
		printf("正在后序遍历二叉树...\n");
		PosOrderTraverse(T->lchild, level + 1);
		PosOrderTraverse(T->rchild, level + 1);
		visit(T->data, level);
	}
}
主函数

int main(){
	BiTree T = NULL;
	int level = 1;
	T = CreateBiTree(T);
	PreOrderTraverse(T, level);
	InOrderTraverse(T, level);
	PosOrderTraverse(T, level);

	getchar();
	getchar();
	getchar();
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值