zoukankan      html  css  js  c++  java
  • 【leetcode】Convert Sorted List to Binary Search Tree (middle)

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

    思路:题目看上去好像很难,但实际上很简单,递归做就行,每次找到左右子树对应的子链表就行。一次AC。

    class Solution {
    public:
        TreeNode *sortedListToBST(ListNode *head) {
            if(head == NULL)
                return NULL;
    
            ListNode * fast = head, *slow = head, *slowpre = head; //分别是快指针、慢指针、慢指针前一个指针 慢指针的位置就是当前平衡树根节点的位置 中间值
            while(fast != NULL && fast->next != NULL)
            {
                fast = fast->next->next;
                slowpre = slow;
                slow = slow->next;    
            }
            TreeNode * root = new TreeNode(slow->val);
            ListNode * left = (slow == head) ? NULL : head; //如果慢指针==头指针 则其左子树是空的
            ListNode * right = slow->next;
            slowpre->next = NULL; //左子树对应的链表末尾置null
            root->left = sortedListToBST(left);
            root->right = sortedListToBST(right);
    
            return root;
        }
    };
  • 相关阅读:
    (考研)散列表和hashcode和hashmap
    java基本数据类型和引用类型
    Java 中的语法糖(7/15整个周六上午总结)
    数据库第一天-数据库索引
    MonoBehaviour生命周期
    Unity基础知识
    SQLite3笔记
    cocos_js写文件
    UGUI_屏幕适配
    KMS算法
  • 原文地址:https://www.cnblogs.com/dplearning/p/4232230.html
Copyright © 2011-2022 走看看