LeetCode 109. Convert Sorted List to Binary Search Tree

Given a singly linked list where elements are sorted in ascending order, convert it to a height balanced BST。

解题思路:对于一个给定个数的有序列表,其形成的平衡二叉树的形状只与它的个数有关,与具体的数值无关。首先可以先计算链表中节点的总个数,然后将中间节点构造成子树根节点,递归构造左右子树。

class Solution {
public:
    TreeNode* sortedListToBST(ListNode* head) {
        ListNode* p=head;
        int count=0;
        while(p!=NULL){
            count++;    //计算总节点个数
            p=p->next;
        }
        if(count==0){
            return NULL;
        }else{
            return helper(head,1,count);    //对总节点数为count的链表进行递归构造平衡二叉树
        }
        
    }
    TreeNode* helper(ListNode* head,int start,int end){
        if(start>end){
            return NULL;
        }else if(start==end){
            ListNode* p=head;
            for(int i=1;i<start;i++){   //从第一个节点开始向后寻找,找到个数是start的节点
                p=p->next;
            }
            return new TreeNode(p->val);
        }
        ListNode* p=head;
        for(int i=1;i<(start+end)/2;i++){ //从第一个节点开始向后寻找,找到个数是(start+end)/2的节点,构造子树的根节点
            p=p->next;
        }
        TreeNode* temphead=new TreeNode(p->val);
        temphead->left=helper(head,start,(start+end)/2-1); //递归构造左子树
        temphead->right=helper(head,(start+end)/2+1,end);   //递归构造右子树
        return temphead;    //返回根节点
    }
};


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值