码迷,mamicode.com
首页 > 编程语言 > 详细

[算法]二叉树创建

时间:2014-12-30 11:42:39      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:二叉树   算法   创建二叉树   

【链式存储结构】

struct TreeNode {
    int val;
    TreeNode *left;
    TreeNode *right;
    TreeNode(int x) : val(x), left(NULL), right(NULL) {}
};

【层次创建二叉树】

// 创建二叉树
TreeNode* CreateTreeByLevel(vector<char> num){
    int len = num.size();
    if(len == 0){
        return NULL;
    }//if
    queue<TreeNode*> queue;
    int index = 0;
    // 创建根节点
    TreeNode *root = new TreeNode(num[index++]);
    // 入队列
    queue.push(root);
    TreeNode *p = NULL;
    while(!queue.empty() && index < len){
        // 出队列
        p = queue.front();
        queue.pop();
        // 左节点
        if(index < len && num[index] != -1){
            // 如果不空创建一个节点
            TreeNode *leftNode = new TreeNode(num[index]);
            p->left = leftNode;
            queue.push(leftNode);
        }
        index++;
        // 右节点
        if(index < len && num[index] != -1){
            // 如果不空创建一个节点
            TreeNode *rightNode = new TreeNode(num[index]);
            p->right = rightNode;
            queue.push(rightNode);
        }
        index++;
    }//while
    return root;
}

-1代表NULL

技术分享

创建如上二叉树输入:

15 11 20 8 14 -1 -1 -1 -1 13 -1

【先序创建二叉树】

//按先序序列创建二叉树  
int CreateBTree(TreeNode*& T){  
    int data;  
    //按先序次序输入二叉树中结点的值,-1表示空树  
    cin>>data;  
    if(data == -1){  
        T = NULL;  
    }  
    else{  
        T = new TreeNode(data);  
        //构造左子树  
        CreateBTree(T->left);  
        //构造右子树  
        CreateBTree(T->right);  
    }  
    return 0;  
} 

-1代表NULL

技术分享

创建如上二叉树输入:

15 11 8 -1 -1 14 13 -1 -1 -1 20 -1 -1




[算法]二叉树创建

标签:二叉树   算法   创建二叉树   

原文地址:http://blog.csdn.net/sunnyyoona/article/details/42263865

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!