Leetcode No.109 有序链表转换二叉搜索树

Posted AI算法攻城狮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Leetcode No.109 有序链表转换二叉搜索树相关的知识,希望对你有一定的参考价值。

一、题目描述

给定一个单链表,其中的元素按升序排序,将其转换为高度平衡的二叉搜索树。

本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1。

示例:

给定的有序链表: [-10, -3, 0, 5, 9],

一个可能的答案是:[0, -3, 9, -10, null, 5], 它可以表示下面这个高度平衡二叉搜索树:

      0
     / \\
   -3   9
   /     /
 -10  5

二、解题思路

4.5.1 二叉排序树_公众号:算法攻城狮-CSDN博客

将给定的有序链表转换为二叉搜索树的第一步是确定根节点。由于我们需要构造出平衡的二叉树,因此比较直观的想法是让根节点左子树中的节点个数与右子树中的节点个数尽可能接近。这样一来,左右子树的高度也会非常接近,可以达到高度差绝对值不超过 1 的题目要求。

如何找出这样的一个根节点呢?我们可以找出链表元素的中位数作为根节点的值。

这里对于中位数的定义为:如果链表中的元素个数为奇数,那么唯一的中间值为中位数;如果元素个数为偶数,那么唯二的中间值都可以作为中位数,而不是常规定义中二者的平均值。

根据中位数的性质,链表中小于中位数的元素个数与大于中位数的元素个数要么相等,要么相差 1。此时,小于中位数的元素组成了左子树,大于中位数的元素组成了右子树,它们分别对应着有序链表中连续的一段。在这之后࿰

以上是关于Leetcode No.109 有序链表转换二叉搜索树的主要内容,如果未能解决你的问题,请参考以下文章

[LeetCode] 109. 有序链表转换二叉搜索树 ☆☆☆(递归)

LeetCode(109):有序链表转换二叉搜索树

[LeetCode] 109. 有序链表转换二叉搜索树

LeetCode 0109.有序链表转换二叉搜索树 - 链表中值为根,中值左右分别为左右子树

LeetCode 109. 有序链表转换二叉搜索树

LeetCode Java刷题笔记—109. 有序链表转换二叉搜索树