树基础(持续更新)

本文介绍了树的基础知识,包括一般的树和二叉树的概念,详细讲解了满二叉树和完全二叉树的特性。通过数组实现二叉树,并探讨了先序、中序和后序遍历的方法。此外,还涉及了堆、二叉堆和优先队列的原理,以及哈夫曼树和Treap、Splay、AVL等自调整树的数据结构。
摘要由CSDN通过智能技术生成

一、一般的树

#include<vector>
struct node{
	int val;
	vector<node*> child; 
}treenode;

二、一般的二叉树

二叉树的每个结点至多只有二棵子树

满二叉树:除最后一层无任何子节点外,每一层上的所有结点都有两个子结点

完全二叉树:若设二叉树的深度为h,除第 h 层外,其它各层 (1~(h-1)层) 的结点数都达到最大个数,第h层所有的结点都连续集中在最左边,这就是完全二叉树

①实现

数组实现,i的左子树2*i,i的右子树2*i+1,i的父亲是i/2

传统实现方法:

struct node{
	int va;
	node* rchild;
	node* lchild;
	node(int x):val(x),rchild(NULL),lchild(NULL){}
}bitree;

②遍历(先序,中序,后序)

void visit(bitree*p){
	cout<<p->val<<' ';
}
void preorder(bitree*p){
	if(!p)return;
	visit(p);
	preorder(p->rchild);
	preorder(p->lchild);
}
void inorder(bitree*p){
	if(!p)return;
	inorder(p->rchild);
	visit(p);
	inorder(p->lchild);
}
void postorder(bitree*p){
	if(!p)return;
	postorder(p->rchild);
	postorder(p->lchild);
	visit(p);
}

三、堆,二叉堆,优先队列

堆:对任意的两个节点A, B,如果BA的孩子节点,那么一定有A.data > B.data,则称之为最大堆,反之为最小堆

二叉堆:一种有堆这个性质的二叉树,使用上浮和下沉两种核心操作来维护整个数据结构,有如下操作:插入,删除,查找

优先队列:将数组实现的二叉树与堆结合起来的数据结构,主要是对堆顶操作

#include<queue>
priority_queue<int> q1;//从大到小 
priority_queue<int,vector<int>,greater<int> > q2;//从小到大
q1.top();
q1.push();
q1.empty();
q1.size(); 
q1.pop();

四、哈夫曼树

先就好好看这个吧:点击打开链接

五、Treap

六、Splay

七、AVL

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值