《算法笔记》读书记录DAY_36

本文介绍了二叉查找树的重要性质及其在数据结构中的应用。通过一道例题展示了如何判断给定序列是否为二叉查找树的先序序列或镜像树的先序序列。同时,讨论了平衡二叉树(AVL树)在降低树高方面的作用。代码示例演示了如何构建并遍历二叉查找树。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CHAPTER_9  提高篇(3)——数据结构(2)

9.4.3二叉查找树的性质

二叉查找树有一个重要性质:对二叉查找树进行中序遍历,遍历的结果是有序的。

另外,如果合理地调整二叉查找树的形态,使得每个子树上的节点尽量都有两个孩子,这样整个BST的高低就会尽可能低,即高度大概在log(N)级别,N是节点个数。能实现这个要求的是一颗平衡二叉树(AVL),参考9.5节。

下面通过一道例题来练习二叉排序树相关。

题目:

给出N个正整数作为一颗二叉排序树的结点插入顺序,问:这串序列是否是该二叉排序树的先序序列或是该二叉排序树的镜像树的先序序列。

镜像树是指交换二叉树的所有结点的左右子树而形成的树。

如果是二叉排序树的先序序列或是该二叉排序树的镜像树的先序序列,则输出YES;否则,输出NO。

输入格式:

每个输入包含一个测试用例。对于每一个用例,第一行给出正整数N,N表示结点的个数。接下来在第二行分别给出N个节点的数据,每个数据间用空格分隔。

输出格式:

对于每一个用例,输出YES或者NO。

输入样例1:

7

8 6 5 7 10 8 11

输出样例1:

YES   //是先序序列

输入样例2:

7

8 10 11 8 6 7 5

输出样例2:

YES   //是镜像树的先序序列

 输入样例3:

7

8 6 8 5 10 9 11

输出样例3:

NO   //既不是先序序列,也不是镜像树的先序序列

思路:

通过给定的序列,构建出二叉排序树。对镜像树的先序遍历只需要在原树的先序遍历时交换左右子树的访问顺序即可。注意使用vector来存放初始序列、先序序列、镜像树的先序序列,这样可以直接进行比较。这是因为当vector内元素为基本数据类型时,可以直接用比较符号(==、>=、!=等)进行判断。

参考代码:

#include <iostream>
#include <vector>

using namespace std;
vector<int> origin,pre,preM;

struct node{
	int data;
	node *left,*right;
};

void insert(node* &root,int x) {
	if(root==NULL) {
		root=new node;
		root->data=x;
		root->left=root->right=NULL;
		return;
	}
	if(x<root->data)
		insert(root->left,x);
	else
		insert(root->right,x);
}

void preOrder(node* root) {
	if(root==NULL)
		return;
	pre.push_back(root->data);
	preOrder(root->left);
	preOrder(root->right);
}

void preOrderMirror(node* root) {
	if(root==NULL)
		return;
	preM.push_back(root->data);
	preOrderMirror(root->right);
	preOrderMirror(root->left);
}


int main() {
	int n,data;
	node *root=NULL;
	cin>>n;
	for(int i=0;i<n;i++) {
		cin>>data;
		origin.push_back(data);
		insert(root,data);
	}
	preOrder(root);
	preOrderMirror(root);
	if(origin==pre||origin==preM)
		cout<<"YES"<<endl;
	else
		cout<<"NO"<<endl;
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值