`
SunnyYoona
  • 浏览: 366837 次
社区版块
存档分类
最新评论

[算法]二叉树创建

 
阅读更多

【链式存储结构】

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




分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics