码迷,mamicode.com
首页 > 其他好文 > 详细

Leetcode:convert_sorted_array_to_binary_search_tree

时间:2015-10-17 17:49:56      阅读:135      评论:0      收藏:0      [点我收藏+]

标签:

一、     称号

排序后的数组成二叉搜索树。

二、     分析

   BST的中序遍历是一个sorted-array,再构造回去成一个BST,先将中间的元素作为根节点,这个节点的左右各自是左子树和右子树。如此递归地进行就可以。

 

/**
 * Definition for binary tree
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public: 
	   TreeNode *sortedArrayToBST(vector<int> &num) {
	    return addNode(num, 0, num.size()-1);
	   }
	   TreeNode *addNode(vector<int> &num, int start, int end){
	    if(start > end) return NULL;
	    
	    int mid = (start + end)/2;
	    TreeNode *root = new TreeNode(num[mid]);
	    root->left = addNode(num, start, mid-1);
	    root->right = addNode(num, mid+1, end);
	    return root;
	   }
};


版权声明:本文博主原创文章。博客,未经同意不得转载。

Leetcode:convert_sorted_array_to_binary_search_tree

标签:

原文地址:http://www.cnblogs.com/mengfanrong/p/4887637.html

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