1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-10 18:48:13 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/合并多棵二叉搜索树 [merge-bsts-to-create-single-bst].html
2022-03-29 12:43:11 +08:00

69 lines
3.5 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<p>给你 <code>n</code><strong>二叉搜索树的根节点</strong> ,存储在数组 <code>trees</code> 中(<strong>下标从 0 开始</strong>),对应 <code>n</code> 棵不同的二叉搜索树。<code>trees</code> 中的每棵二叉搜索树 <strong>最多有 3 个节点</strong> ,且不存在值相同的两个根节点。在一步操作中,将会完成下述步骤:</p>
<ul>
<li>选择两个 <strong>不同的</strong> 下标 <code>i</code><code>j</code> ,要求满足在&nbsp;<code>trees[i]</code> 中的某个 <strong>叶节点</strong> 的值等于&nbsp;<code>trees[j]</code><strong>根节点的值</strong></li>
<li>&nbsp;<code>trees[j]</code> 替换 <code>trees[i]</code> 中的那个叶节点。</li>
<li><code>trees</code> 中移除 <code>trees[j]</code></li>
</ul>
<p>如果在执行 <code>n - 1</code> 次操作后,能形成一棵有效的二叉搜索树,则返回结果二叉树的 <strong>根节点</strong> ;如果无法构造一棵有效的二叉搜索树<em></em>返回<em> </em><code>null</code></p>
<p>二叉搜索树是一种二叉树,且树中每个节点均满足下述属性:</p>
<ul>
<li>任意节点的左子树中的值都 <strong>严格小于</strong>&nbsp;此节点的值。</li>
<li>任意节点的右子树中的值都 <strong>严格大于</strong>&nbsp;此节点的值。</li>
</ul>
<p>叶节点是不含子节点的节点。</p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<img alt="" src="https://assets.leetcode.com/uploads/2021/06/08/d1.png" />
<pre>
<strong>输入:</strong>trees = [[2,1],[3,2,5],[5,4]]
<strong>输出:</strong>[3,2,5,1,null,4]
<strong>解释:</strong>
第一步操作中,选出 i=1 和 j=0 ,并将 trees[0] 合并到 trees[1] 中。
删除 trees[0] trees = [[3,2,5,1],[5,4]] 。
<img alt="" src="https://assets.leetcode.com/uploads/2021/06/24/diagram.png" />
在第二步操作中,选出 i=0 和 j=1 ,将 trees[1] 合并到 trees[0] 中。
删除 trees[1] trees = [[3,2,5,1,null,4]] 。
<img alt="" src="https://assets.leetcode.com/uploads/2021/06/24/diagram-2.png" />
结果树如上图所示,为一棵有效的二叉搜索树,所以返回该树的根节点。</pre>
<p><strong>示例 2</strong></p>
<img alt="" src="https://assets.leetcode.com/uploads/2021/06/08/d2.png" />
<pre>
<strong>输入:</strong>trees = [[5,3,8],[3,2,6]]
<strong>输出:</strong>[]
<strong>解释:</strong>
选出 i=0 和 j=1 ,然后将 trees[1] 合并到 trees[0] 中。
删除 trees[1] trees = [[5,3,8,2,6]] 。
<img alt="" src="https://assets.leetcode.com/uploads/2021/06/24/diagram-3.png" />
结果树如上图所示。仅能执行一次有效的操作,但结果树不是一棵有效的二叉搜索树,所以返回 null 。
</pre>
<p><strong>示例 3</strong></p>
<img alt="" src="https://assets.leetcode.com/uploads/2021/06/08/d3.png" />
<pre>
<strong>输入:</strong>trees = [[5,4],[3]]
<strong>输出:</strong>[]
<strong>解释:</strong>无法执行任何操作。
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>n == trees.length</code></li>
<li><code>1 &lt;= n &lt;= 5 * 10<sup>4</sup></code></li>
<li>每棵树中节点数目在范围 <code>[1, 3]</code> 内。</li>
<li>输入数据的每个节点可能有子节点但不存在子节点的子节点</li>
<li><code>trees</code> 中不存在两棵树根节点值相同的情况。</li>
<li>输入中的所有树都是 <strong>有效的二叉树搜索树</strong></li>
<li><code>1 &lt;= TreeNode.val &lt;= 5 * 10<sup>4</sup></code>.</li>
</ul>