1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-27 18:50:26 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/删除给定值的叶子节点 [delete-leaves-with-a-given-value].html

57 lines
2.3 KiB
HTML
Raw Normal View History

2022-03-27 20:37:52 +08:00
<p>给你一棵以&nbsp;<code>root</code>&nbsp;为根的二叉树和一个整数&nbsp;<code>target</code>&nbsp;,请你删除所有值为&nbsp;<code>target</code>&nbsp;<strong>叶子节点</strong></p>
<p>注意,一旦删除值为&nbsp;<code>target</code>&nbsp;的叶子节点,它的父节点就可能变成叶子节点;如果新叶子节点的值恰好也是&nbsp;<code>target</code> ,那么这个节点也应该被删除。</p>
<p>也就是说,你需要重复此过程直到不能继续删除。</p>
<p>&nbsp;</p>
<p><strong>示例 1</strong></p>
<p><strong><img alt="" src="https://assets.leetcode-cn.com/aliyun-lc-upload/uploads/2020/01/16/sample_1_1684.png" style="height: 120px; width: 550px;"></strong></p>
<pre><strong>输入:</strong>root = [1,2,3,2,null,2,4], target = 2
<strong>输出:</strong>[1,null,3,null,4]
<strong>解释:
</strong>上面左边的图中,绿色节点为叶子节点,且它们的值与 target 相同(同为 2 ),它们会被删除,得到中间的图。
有一个新的节点变成了叶子节点且它的值与 target 相同,所以将再次进行删除,从而得到最右边的图。
</pre>
<p><strong>示例 2</strong></p>
<p><strong><img alt="" src="https://assets.leetcode-cn.com/aliyun-lc-upload/uploads/2020/01/16/sample_2_1684.png" style="height: 120px; width: 300px;"></strong></p>
<pre><strong>输入:</strong>root = [1,3,3,3,2], target = 3
<strong>输出:</strong>[1,3,null,null,2]
</pre>
<p><strong>示例 3</strong></p>
<p><strong><img alt="" src="https://assets.leetcode-cn.com/aliyun-lc-upload/uploads/2020/01/16/sample_3_1684.png" style="width: 450px;"></strong></p>
<pre><strong>输入:</strong>root = [1,2,null,2,null,2], target = 2
<strong>输出:</strong>[1]
<strong>解释:</strong>每一步都删除一个绿色的叶子节点(值为 2</pre>
<p><strong>示例 4</strong></p>
<pre><strong>输入:</strong>root = [1,1,1], target = 1
<strong>输出:</strong>[]
</pre>
<p><strong>示例 5</strong></p>
<pre><strong>输入:</strong>root = [1,2,3], target = 1
<strong>输出:</strong>[1,2,3]
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>1 &lt;= target&nbsp;&lt;= 1000</code></li>
<li>每一棵树最多有 <code>3000</code> 个节点。</li>
<li>每一个节点值的范围是&nbsp;<code>[1, 1000]</code>&nbsp;</li>
</ul>