[Leetcode] Convert Sorted List to Binary Search Tree
2012-12-03 04:07
543 查看
/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */ /** * 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 *sortedListToBST(ListNode *head) { // Start typing your C/C++ solution below // DO NOT write int main() function int cnt = 0; ListNode* cur = head; while (cur) { cur = cur->next; cnt++; } return build(head, 0, cnt - 1); } TreeNode* build(ListNode* &head, int left, int right) { if (left > right) return NULL; int mid = left + (right - left) / 2; TreeNode* leftChild = build(head, left, mid - 1); TreeNode* parent = new TreeNode(head->val); parent->left = leftChild; head = head->next; parent->right = build(head, mid + 1, right); return parent; } };
相关文章推荐
- LeetCode Convert Sorted List to Binary Search Tree
- 5 Convert Sorted List to Binary Search Tree_Leetcode
- leetcode 109 —— Convert Sorted List to Binary Search Tree
- [LeetCode]Convert Sorted List to Binary Search Tree
- 【Leetcode】Convert Sorted List to Binary Search Tree
- Leetcode:Convert Sorted List to Binary Search Tree
- leetcode Convert Sorted List to Binary Search Tree
- LeetCode:Convert Sorted List to Binary Search Tree
- [leetcode] Convert Sorted List to Binary Search Tree
- leetcode[109]:Convert Sorted List to Binary Search Tree
- LeetCode-Convert Sorted List to Binary Search Tree
- LeetCode:Convert Sorted Array(List) to Binary Search Tree
- 【leetcode】【单链表】【109】Convert Sorted List to Binary Search Tree
- LeetCode刷题(C++)——Convert Sorted List to Binary Search Tree(Normal)
- LeetCode109 Convert Sorted List to Binary Search Tree
- [LeetCode]题解(python):109-Convert Sorted List to Binary Search Tree
- Leetcode习题:Convert Sorted List to Binary Search Tree
- LeetCode Convert Sorted List to Binary Search Tree
- Convert Sorted List to Binary Search Tree [LeetCode]
- [LeetCode 109] - 将已排序链表转换为二叉搜索树 (Convert Sorted List to Binary Search Tree)