mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-10 18:48:13 +08:00
40 lines
2.2 KiB
HTML
40 lines
2.2 KiB
HTML
<p>有一棵 <code>n</code> 个节点的无向树,节点编号为 <code>0</code> 到 <code>n - 1</code> 。</p>
|
||
|
||
<p>给你一个长度为 <code>n</code> 下标从 <strong>0</strong> 开始的整数数组 <code>nums</code> ,其中 <code>nums[i]</code> 表示第 <code>i</code> 个节点的值。同时给你一个长度为 <code>n - 1</code> 的二维整数数组 <code>edges</code> ,其中 <code>edges[i] = [a<sub>i</sub>, b<sub>i</sub>]</code> 表示节点 <code>a<sub>i</sub></code> 与 <code>b<sub>i</sub></code> 之间有一条边。</p>
|
||
|
||
<p>你可以 <strong>删除</strong> 一些边,将这棵树分成几个连通块。一个连通块的 <strong>价值</strong> 定义为这个连通块中 <strong>所有</strong> 节点 <code>i</code> 对应的 <code>nums[i]</code> 之和。</p>
|
||
|
||
<p>你需要删除一些边,删除后得到的各个连通块的价值都相等。请返回你可以删除的边数 <strong>最多</strong> 为多少。</p>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>示例 1:</strong></p>
|
||
|
||
<p><img alt="" src="https://assets.leetcode.com/uploads/2022/08/26/diagramdrawio.png" style="width: 441px; height: 351px;"></p>
|
||
|
||
<pre><b>输入:</b>nums = [6,2,2,2,6], edges = [[0,1],[1,2],[1,3],[3,4]]
|
||
<b>输出:</b>2
|
||
<b>解释:</b>上图展示了我们可以删除边 [0,1] 和 [3,4] 。得到的连通块为 [0] ,[1,2,3] 和 [4] 。每个连通块的价值都为 6 。可以证明没有别的更好的删除方案存在了,所以答案为 2 。
|
||
</pre>
|
||
|
||
<p><strong>示例 2:</strong></p>
|
||
|
||
<pre><b>输入:</b>nums = [2], edges = []
|
||
<b>输出:</b>0
|
||
<b>解释:</b>没有任何边可以删除。
|
||
</pre>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>提示:</strong></p>
|
||
|
||
<ul>
|
||
<li><code>1 <= n <= 2 * 10<sup>4</sup></code></li>
|
||
<li><code>nums.length == n</code></li>
|
||
<li><code>1 <= nums[i] <= 50</code></li>
|
||
<li><code>edges.length == n - 1</code></li>
|
||
<li><code>edges[i].length == 2</code></li>
|
||
<li><code>0 <= edges[i][0], edges[i][1] <= n - 1</code></li>
|
||
<li><code>edges</code> 表示一棵合法的树。</li>
|
||
</ul>
|