2025-01-09 20:29:41 +08:00
|
|
|
|
<p>给你一个 <code>n</code> 个节点的无向无根树,节点编号从 <code>0</code> 到 <code>n - 1</code> 。给你整数 <code>n</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> 之间有一条边。再给你一个长度为 <code>n</code> 的数组 <code>coins</code> ,其中 <code>coins[i]</code> 可能为 <code>0</code> 也可能为 <code>1</code> ,<code>1</code> 表示节点 <code>i</code> 处有一个金币。</p>
|
|
|
|
|
|
|
|
|
|
<p>一开始,你需要选择树中任意一个节点出发。你可以执行下述操作任意次:</p>
|
|
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
|
<li>收集距离当前节点距离为 <code>2</code> 以内的所有金币,或者</li>
|
|
|
|
|
<li>移动到树中一个相邻节点。</li>
|
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
|
|
<p>你需要收集树中所有的金币,并且回到出发节点,请你返回最少经过的边数。</p>
|
|
|
|
|
|
|
|
|
|
<p>如果你多次经过一条边,每一次经过都会给答案加一。</p>
|
|
|
|
|
|
|
|
|
|
<p> </p>
|
|
|
|
|
|
|
|
|
|
<p><strong>示例 1:</strong></p>
|
|
|
|
|
|
|
|
|
|
<p><img alt="" src="https://assets.leetcode.com/uploads/2023/03/01/graph-2.png" style="width: 522px; height: 522px;"></p>
|
|
|
|
|
|
|
|
|
|
<pre><b>输入:</b>coins = [1,0,0,0,0,1], edges = [[0,1],[1,2],[2,3],[3,4],[4,5]]
|
|
|
|
|
<b>输出:</b>2
|
|
|
|
|
<b>解释:</b>从节点 2 出发,收集节点 0 处的金币,移动到节点 3 ,收集节点 5 处的金币,然后移动回节点 2 。
|
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
|
|
<p><strong>示例 2:</strong></p>
|
|
|
|
|
|
|
|
|
|
<p><img alt="" src="https://assets.leetcode.com/uploads/2023/03/02/graph-4.png" style="width: 522px; height: 522px;"></p>
|
|
|
|
|
|
|
|
|
|
<pre><b>输入:</b>coins = [0,0,0,1,1,0,0,1], edges = [[0,1],[0,2],[1,3],[1,4],[2,5],[5,6],[5,7]]
|
|
|
|
|
<b>输出:</b>2
|
|
|
|
|
<b>解释:</b>从节点 0 出发,收集节点 4 和 3 处的金币,移动到节点 2 处,收集节点 7 处的金币,移动回节点 0 。
|
|
|
|
|
</pre>
|
|
|
|
|
|
|
|
|
|
<p> </p>
|
|
|
|
|
|
|
|
|
|
<p><strong>提示:</strong></p>
|
|
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
|
<li><code>n == coins.length</code></li>
|
|
|
|
|
<li><code>1 <= n <= 3 * 10<sup>4</sup></code></li>
|
|
|
|
|
<li><code>0 <= coins[i] <= 1</code></li>
|
|
|
|
|
<li><code>edges.length == n - 1</code></li>
|
|
|
|
|
<li><code>edges[i].length == 2</code></li>
|
|
|
|
|
<li><code>0 <= a<sub>i</sub>, b<sub>i</sub> < n</code></li>
|
|
|
|
|
<li><code>a<sub>i</sub> != b<sub>i</sub></code></li>
|
|
|
|
|
<li><code>edges</code> 表示一棵合法的树。</li>
|
|
|
|
|
</ul>
|