完全二叉树的4种遍历方式

一张二叉树的图

 1,二叉树的特点

  1. 每个点p的左儿子是p*2,右儿子是p*2+1,可以分别表示为p<<1与p<<1|1
  2. 节点的序号是从左到右,从上到下增加的
  3. 每个点至多2个儿子(屁话(bushi))

2,先序遍历(根左右)

就是每次到子树的根节点,先存入这个节点,然后优先访问左儿子,左儿子访问到回来,再访问右儿子(不是亲生的(que ren))

 顺序1->2->4->5(正在回家的路上)->3->6

int t[N];//t表示树上节点
int cnt;
void build(int p)
{
	cout<<t[p];//每次存储根节点后进入左儿子
	build(p<<1);
	build(p<<1|1);//左儿子出来后再进入右儿子
}

3,中序遍历(左根右)

每次到子树的根节点,先进入左儿子,回来后在访问根,最后再访问右儿子

 顺序4->2->5->1->6->3

int t[N];//t表示树上节点
int cnt;
void build(int p)
{
	build(p<<1);//每次x先进入左儿子,出来后再存储根节点
	cout<<t[p];
	build(p<<1|1);//根节点存储后后再进入右儿子
}

4,后序遍历(左右根)

依次访问左右儿子,再回来访问根节点

顺序是4->5->2->3->6->1

int t[N];//t表示树上节点
int cnt;
void build(int p)
{
	build(p<<1);//每次x先进入左儿子
	build(p<<1|1);//再进入右儿子
	cout<<t[p];//最后存储根节点
}

5,层序遍历

就是一层一层访问,这次不再是遍历了,我们观察序号,其实

t[1]~t[n]就是点1~n的层序遍历

int t[N];//t表示树上节点
int cnt;
for (int i=1; i<=n; ++i)cout<<t[i]<<endl;

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值