当前位置: 首页 > news >正文

LC109. 有序链表转换平衡二叉搜索树

LC109. 有序链表转换平衡二叉搜索树

    • 题目要求
    • (一)快慢指针
      • 1. 理解问题
      • 2. 解决思路
      • 3. 具体步骤
      • 4. 代码实现
      • 5. 复杂度分析
      • 6. 示例解释
      • 7. 总结

LC109. 有序链表转换平衡二叉搜索树

题目要求

在这里插入图片描述

(一)快慢指针

要将一个按升序排列的单链表转换为平衡的二叉搜索树(BST),可以采用以下步骤:

1. 理解问题

  • 单链表:链表中的节点按升序排列。
  • 平衡二叉搜索树:树的左右子树高度差不超过1,且左子树的值小于根节点,右子树的值大于根节点。

2. 解决思路

由于链表是升序排列的,我们可以将其视为二叉搜索树的中序遍历结果。为了构建平衡的BST,我们需要找到链表的中间节点作为根节点,然后递归地构建左子树和右子树。

3. 具体步骤

  1. 找到链表的中间节点

    • 使用快慢指针法找到链表的中间节点。快指针每次走两步,慢指针每次走一步,当快指针到达链表末尾时,慢指针指向的就是中间节点。
  2. 递归构建BST

    • 将中间节点作为根节点。
    • 递归地构建左子树(链表的前半部分)和右子树(链表的后半部分)。
  3. 处理边界条件

    • 如果链表为空,返回 null
    • 如果链表只有一个节点,直接返回该节点作为树的根节点。

4. 代码实现

class ListNode:
    def __init__(self, val=0, next=None):
        self.val = val
        self.next = next

class TreeNode:
    def __init__(self, val=0, left=None, right=None):
        self.val = val
        self.left = left
        self.right = right

def sortedListToBST(head):
    if not head:
        return None
    
    # 找到链表的中间节点
    def findMiddle(head):
        slow = head
        fast = head
        prev = None
        
        while fast and fast.next:
            prev = slow
            slow = slow.next
            fast = fast.next.next
        
        # 断开链表
        if prev:
            prev.next = None
        
        return slow
    
    # 递归构建BST
    def buildBST(head):
        if not head:
            return None
        
        mid = findMiddle(head)
        root = TreeNode(mid.val)
        
        # 如果只有一个节点,直接返回
        if head == mid:
            return root
        
        # 递归构建左子树和右子树
        root.left = buildBST(head)
        root.right = buildBST(mid.next)
        
        return root
    
    return buildBST(head)

5. 复杂度分析

  • 时间复杂度:O(N log N),其中 N 是链表的长度。每次递归都需要找到中间节点,时间复杂度为 O(N),递归深度为 O(log N)。
  • 空间复杂度:O(log N),递归栈的深度为 O(log N)。

6. 示例解释

对于输入 head = [-10,-3,0,5,9]

  • 中间节点是 0,作为根节点。
  • 左子树由 [-10, -3] 构建,右子树由 [5, 9] 构建。
  • 最终得到的平衡BST为 [0,-3,9,-10,null,5]

7. 总结

通过找到链表的中间节点并将其作为根节点,然后递归地构建左子树和右子树,我们可以将一个升序链表转换为一个平衡的二叉搜索树。这种方法既保证了树的平衡性,又充分利用了链表的升序特性。

相关文章:

  • 【操作系统】设备管理
  • 多机多卡训练和单机多卡训练速度对比
  • VTP协议故障排除——三层交换机
  • MySQL零基础教程15—简单的表连接(join)
  • Windows系统还原详解
  • 51单片机使用DS18B20温度传感器
  • day27 第八章 贪心算法 part01
  • 深度学习R8周:RNN实现阿尔兹海默症(pytorch)
  • 补丁供应链案例:CVE-2024-7254. Protobuf. Google
  • FastGPT 引申:知识库辅助开发(代码符号自动提取与文件匹配工具详解)
  • FastGPT 引申:如何基于 LLM 判断知识库的好坏
  • cesium+vue3自定义HTML实体弹窗、加高德路网、防实体漂浮、让用户画圆、鹰眼
  • 51c自动驾驶~合集53
  • 从建筑设计到施工工具:软件体系结构与框架的协同之道
  • el-input 设置类型为number时,输入中文后光标会上移,并且会出现上下箭头
  • RK3568平台(GPIO篇)libgpiod的使用
  • 为AI聊天工具添加一个知识系统 之133 详细设计之74通用编程语言 之4 架构及其核心
  • AI学习笔记:LM studio大模型加载参数说明
  • Hutool一个类型转换工具类 `Convert`,
  • Redis——缓存穿透、击穿、雪崩
  • 网站开发需要redis/合肥百度推广公司哪家好
  • 抖音橙子建站官网/站长全网指数查询
  • 做网站卖仿品/nba最新消息新闻
  • 龙岩网站建设方案/零基础能做网络推广吗
  • 南山做网站多少钱/推广网站推广
  • 网站的详情页面/百度竞价推广登录