题解 | #二叉排序树#

二叉排序树

http://www.nowcoder.com/practice/b42cfd38923c4b72bde19b795e78bcb3

#include<iostream>
#include<cstdio>
#include<string>

using namespace std;

struct TreeNode {
	int data;
	TreeNode* leftChild;
	TreeNode* rightChild;
	TreeNode(int x):data(x),leftChild(nullptr),rightChild(nullptr) {}
};

const int MAXN = 100 + 10;

int arr[MAXN];

void PreOrder(TreeNode* root) {
	if(root == nullptr) {
		return;
	}
	printf("%d ",root->data);
	PreOrder(root->leftChild);
	PreOrder(root->rightChild);
	return;
}
void InOrder(TreeNode* root) {
	if(root == nullptr) {
		return;
	}
	InOrder(root->leftChild);
	printf("%d ",root->data);
	InOrder(root->rightChild);
	return;
}
void PostOrder(TreeNode* root) {
	if(root == nullptr) {
		return;
	}
	PostOrder(root->leftChild);
	PostOrder(root->rightChild);
	printf("%d ",root->data);
	return;
}

TreeNode* Build(TreeNode* root,int x) {  //root为根节点,x为构建时需要的值
	if(root == nullptr) {
		root = new TreeNode(x);
	} else if(x < root->data) {  //
		root->leftChild = Build(root->leftChild,x);
	} else if(x > root->data) {
		root->rightChild = Build(root->rightChild,x);
	}
	return root;
}

int main() {
	int n;
	while(scanf("%d",&n) != EOF) {
		TreeNode* root = nullptr;
		while(n--) {
			int x;
			scanf("%d",&x);
			root = Build(root,x);
		}
		PreOrder(root);
		printf("\n");
		InOrder(root);
		printf("\n");
		PostOrder(root);
        printf("\n");
	}
	return 0;
}
全部评论

相关推荐

点赞 评论 收藏
分享
门口唉提是地铁杀:之前b站被一个游戏demo深深的吸引了。看up主页发现是个初创公司,而且还在招人,也是一天60。二面的时候要我做一个登录验证和传输文件两个微服务,做完要我推到github仓库,还要我加上jaeger和一堆运维工具做性能测试并且面试的时候投屏演示。我傻乎乎的做完以后人家跟我说一句现在暂时不招人,1分钱没拿到全是白干
你的秋招第一场笔试是哪家
点赞 评论 收藏
分享
05-22 17:07
已编辑
门头沟学院 Java
程序员牛肉:都啥时候了还jb打蓝桥杯呢,有限找实习。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务