前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >二叉树双亲表示法

二叉树双亲表示法

作者头像
我与梦想有个约会
发布2023-10-20 17:12:04
1380
发布2023-10-20 17:12:04
举报
文章被收录于专栏:jiajia_dengjiajia_deng

前面我们介绍过二叉树的单向表示和双向表示发,分别是借用了几个指针来实现。双亲表示法则是用了一个非常详细的结构体描述了一个节点,然后将节点串联到另外一个结构体中(这个结构体包含一个数组),具体的代码如下:

代码语言:javascript
复制
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
/////////// 双亲表示法 ///////////
typedef struct tag_BPTNode
{
//节点数据
char data;
//指向父节点的变量(数组下标)
int parentPosition;
//左右孩子标志域
char LRTag;
}BPTNode;
//定义树的数据结构
typedef struct tag_BPTree
{
//一个代表整个树的数组
BPTNode nodes[100];
//树中已经存入节点的个数
int num_node;
//根节点的位置(***注意此域存储的是父亲节点在数组中的下标***)
int root;
}BPTree;
int main()
{
//定义一个变量, 最多可容纳100个节点
BPTree tree;
//初始化
memset(&tree, 0, sizeof(BPTNode));
tree.root = 0;//0号位置元素为根节点
//根节点
tree.nodes[0].data = ‘a’;
tree.num_node++;//节点数加1
//B
tree.nodes[1].data = ‘b’;
tree.nodes[1].parentPosition = 0;//父亲是a
tree.nodes[1].LRTag = 1;//a的左孩子
tree.num_node++;//节点数加1
//c
tree.nodes[2].data = ‘c’;
tree.nodes[2].parentPosition = 0;//父亲是a
tree.nodes[2].LRTag = 2;//a的右孩子
tree.num_node++;//节点数加1
//d
tree.nodes[3].data = ‘d’;
tree.nodes[3].parentPosition = 1;//父亲是b
tree.nodes[3].LRTag = 1;//b的左孩子
tree.num_node++;//节点数加1
//e
tree.nodes[4].data = ‘e’;
tree.nodes[4].parentPosition = 1;//父亲是b
tree.nodes[4].LRTag = 2;//b的右孩子
tree.num_node++;//节点数加1
//f
tree.nodes[5].data = ‘f’;
tree.nodes[5].parentPosition = 2;//父亲是c
tree.nodes[5].LRTag = 1;//c的左孩子
tree.num_node++;//节点数加1
//g
tree.nodes[6].data = ‘g’;
tree.nodes[6].parentPosition = 2;//父亲是c
tree.nodes[6].LRTag = 2;//a的左孩子
tree.num_node++;//节点数加1
return 0;
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015-06-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档