二叉树的构建和遍历


http://blog.csdn.net/bitboss/article/details/53310234

#include <stdio.h>
#include <malloc.h>
typedef struct Node
{
    struct Node* left;
    struct Node* right;
    int data;
} node;

int index=0;
//前序创建二叉树 
node* create_tree(int array[], int size, int data)
{
    node* root = NULL;
    if(index<size && array[index]!='#')
    {    
        root = (node*)malloc(sizeof(node));
        ++index;
        root->left = create_tree(array, size, data);
        ++index;
        root->right = create_tree(array, size, data);
    }
    return root;
}
int max_distance(node *root, int maxlenth)
{
    if(root == NULL)
        return 0;
    int LeftDepth = max_distance(root->left, maxlenth);
    int RightDepth = max_distance(root->right, maxlenth);
    int temp = LeftDepth + RightDepth;
    if(temp > maxlenth)
        maxlenth = temp;
    return LeftDepth>RightDepth?LeftDepth+1:RightDepth+1;
}
int main()
{
    int array[15] = {1,2,1,3,'#','#',4,5,'#',6,'#',7,'#','#',8};

    node *root = create_tree(array, 15, '#');
    int maxlenth=0;
    int max = max_distance(root, maxlenth);
    printf("%d\n", max); 
    return 0;
} 

优质内容筛选与推荐>>
1、GCC入门知识(转载)
2、对文件的操作
3、30Springd的包扫描——<context:component-scan base-package=” ”/>
4、BBbacktrace installation
5、[Oracle]Oracle良性SQL建议


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号