mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-27 02:30:28 +08:00
46 lines
1.8 KiB
HTML
46 lines
1.8 KiB
HTML
<p><strong>完全二叉树</strong> 是每一层(除最后一层外)都是完全填充(即,节点数达到最大)的,并且所有的节点都尽可能地集中在左侧。</p>
|
||
|
||
<p>设计一种算法,将一个新节点插入到一个完整的二叉树中,并在插入后保持其完整。</p>
|
||
|
||
<p>实现 <code>CBTInserter</code> 类:</p>
|
||
|
||
<ul>
|
||
<li><code>CBTInserter(TreeNode root)</code> 使用头节点为 <code>root</code> 的给定树初始化该数据结构;</li>
|
||
<li><code>CBTInserter.insert(int v)</code> 向树中插入一个值为 <code>Node.val == val</code>的新节点 <code>TreeNode</code>。使树保持完全二叉树的状态,<strong>并返回插入节点</strong> <code>TreeNode</code> <strong>的父节点的值</strong>;</li>
|
||
<li><code>CBTInserter.get_root()</code> 将返回树的头节点。</li>
|
||
</ul>
|
||
|
||
<p> </p>
|
||
|
||
<ol>
|
||
</ol>
|
||
|
||
<p><strong>示例 1:</strong></p>
|
||
|
||
<p><img src="https://assets.leetcode.com/uploads/2021/08/03/lc-treeinsert.jpg" style="height: 143px; width: 500px;" /></p>
|
||
|
||
<pre>
|
||
<strong>输入</strong>
|
||
["CBTInserter", "insert", "insert", "get_root"]
|
||
[[[1, 2]], [3], [4], []]
|
||
<strong>输出</strong>
|
||
[null, 1, 2, [1, 2, 3, 4]]
|
||
|
||
<strong>解释</strong>
|
||
CBTInserter cBTInserter = new CBTInserter([1, 2]);
|
||
cBTInserter.insert(3); // 返回 1
|
||
cBTInserter.insert(4); // 返回 2
|
||
cBTInserter.get_root(); // 返回 [1, 2, 3, 4]</pre>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>提示:</strong></p>
|
||
|
||
<ul>
|
||
<li>树中节点数量范围为 <code>[1, 1000]</code> </li>
|
||
<li><code>0 <= Node.val <= 5000</code></li>
|
||
<li><code>root</code> 是完全二叉树</li>
|
||
<li><code>0 <= val <= 5000</code> </li>
|
||
<li>每个测试用例最多调用 <code>insert</code> 和 <code>get_root</code> 操作 <code>10<sup>4</sup></code> 次</li>
|
||
</ul>
|