二叉树的建立
-
二叉树的数据结构
typedef struct node
{
int data;
struct node* left;
struct node* right;
/* data */
} Node; -
简单创建节点
int main() {
Node n1;
Node n2;
Node n3;
Node n4;
n1.data = 5;
n2.data = 6;
n3.data = 7;
n4.data = 8;
//这时候节点没有连接起来 对节点进行连接
n1.left = &n2; //n2是一个数据实体 而left需要是一个指针 取n2的地址拼到n1的左边上去
n1.right = &n3;
n2.left = &n4;
n2.right = NULL; //即使没东西也要 给出NULL
n3.left = NULL;
n3.right = NULL;
n4.left = NULL;
n4.right = NULL;
//创建成功
//先序遍历验证
preorder(&n1);//放入一个指针地址 作为头节点
} -
通过遍历树来确认是否是一个真正的二叉树
//先序遍历 递归
void preorder(Node* node){
if(node != NULL){
printf("%d ",node -> data);
preorder(node -> left);
preorder(node -> right);
}
}
-
输出结果
-
中序和后续遍历
//中序遍历 递归
void inorder(Node* node){
if(node != NULL){
inorder(node -> left);
printf("%d ",node -> data);
inorder(node -> right);
}
}
//后序遍历 递归
void postorder(Node* node){
if(node != NULL){
postorder(node -> left);
postorder(node -> right);
printf("%d ",node -> data);
}
} -
改写创建树的代码
void createBiTree(BiTree *T)
{
char ch;
scanf ("%c", &ch); //如果是字符型 %c 回车输入 算一个字符,ubutun会一直递归
if (ch == '#')//扩展二叉树,虚结点 == 0
{
*T = NULL;
}
else
{
*T = (BiTree )malloc(sizeof(BiTNode)); //!!! stdlib.h 头文件一定要加!!!
if (!*T)
{
exit(-1); //错误退出
}
(*T)->data = ch; //生成根结点
createBiTree(&((*T)->lchild)); //构造左子树
createBiTree(&((*T)->rchild)); //构造右子树
}
} -
最终代码