二叉树树 from ZZJ

Posted kingpenguin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二叉树树 from ZZJ相关的知识,希望对你有一定的参考价值。

#include<stdio.h>
#include <stdlib.h>
typedef struct Bitnode {
    int val;
    struct Bitnode *left;
    struct Bitnode *right;
}Bitnode;
Bitnode *CreatBitree_level()
{
    int front = 1, rear = 0, x;
    struct Bitnode *q[1234], *t, *root = NULL;
    while(scanf("%d",&x),x != -1)
    {
        if(x == 0)
            t=NULL;
        else
        {
            t = (Bitnode *)malloc(sizeof(Bitnode));
            t->val = x;
            t->right = NULL;
            t->left = NULL;
        }

        q[++rear] = t;
        if(rear == 1)
            root = t;
        else
        {
            if(t && q[front])
            {
                 ( rear%2 == 0 )? (q[front]->left = t):(q[front]->right = t);
                 //加到左子树 或 右子树
            }
            if(rear % 2 == 1)
                front++;
        }
    }
    return root;
}
int s = 0;
void dfs(struct Bitnode *rt,int ans){
    s = ans > s ? ans : s;
    if(!rt) return;
    dfs(rt->left,ans+1);
    dfs(rt->right,ans+1);
}
int depth(struct Bitnode *rt){
    s = 0;
    dfs(rt,0);
    return s;
}//求树高

void preorder(struct Bitnode *rt){
    if(!rt) return ;
    printf(" %d",rt->val);
    preorder(rt->left);
    preorder(rt->right);
}

void inorder(struct Bitnode *rt){
    if(!rt) return;
    inorder(rt->left);
    printf(" %d",rt->val);
    inorder(rt->right);
}

void postorder(struct Bitnode *rt){
    if(!rt) return;
    postorder(rt->left);
    postorder(rt->right);
    printf(" %d",rt->val);
}

int main()
{
    Bitnode *t;
    int n;
    scanf("%d",&n);
    while(n--)
    {
        t = CreatBitree_level();
        printf("%d",depth(t));
        inorder(t);
        printf("
");
    }
    return 0;
}

 

以上是关于二叉树树 from ZZJ的主要内容,如果未能解决你的问题,请参考以下文章

6二叉树树(java实现)

数据结构-树树二叉树森林的转换

二叉树--倒序层序遍历求二叉树树左下角的值

二叉树树的子结构

软考笔记(数据结构篇)———— 二叉树树森林转换

AVL排序二叉树树