1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-10-25 23:08:57 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
Files
leetcode-problemset/leetcode-cn/problem (English)/重构一棵树的方案数(English) [number-of-ways-to-reconstruct-a-tree].html
2022-03-29 12:43:11 +08:00

62 lines
2.5 KiB
HTML

<p>You are given an array <code>pairs</code>, where <code>pairs[i] = [x<sub>i</sub>, y<sub>i</sub>]</code>, and:</p>
<ul>
<li>There are no duplicates.</li>
<li><code>x<sub>i</sub> &lt; y<sub>i</sub></code></li>
</ul>
<p>Let <code>ways</code> be the number of rooted trees that satisfy the following conditions:</p>
<ul>
<li>The tree consists of nodes whose values appeared in <code>pairs</code>.</li>
<li>A pair <code>[x<sub>i</sub>, y<sub>i</sub>]</code> exists in <code>pairs</code> <strong>if and only if</strong> <code>x<sub>i</sub></code> is an ancestor of <code>y<sub>i</sub></code> or <code>y<sub>i</sub></code> is an ancestor of <code>x<sub>i</sub></code>.</li>
<li><strong>Note:</strong> the tree does not have to be a binary tree.</li>
</ul>
<p>Two ways are considered to be different if there is at least one node that has different parents in both ways.</p>
<p>Return:</p>
<ul>
<li><code>0</code> if <code>ways == 0</code></li>
<li><code>1</code> if <code>ways == 1</code></li>
<li><code>2</code> if <code>ways &gt; 1</code></li>
</ul>
<p>A <strong>rooted tree</strong> is a tree that has a single root node, and all edges are oriented to be outgoing from the root.</p>
<p>An <strong>ancestor</strong> of a node is any node on the path from the root to that node (excluding the node itself). The root has no ancestors.</p>
<p>&nbsp;</p>
<p><strong>Example 1:</strong></p>
<img src="https://assets.leetcode.com/uploads/2020/12/03/trees2.png" style="width: 208px; height: 221px;" />
<pre>
<strong>Input:</strong> pairs = [[1,2],[2,3]]
<strong>Output:</strong> 1
<strong>Explanation:</strong> There is exactly one valid rooted tree, which is shown in the above figure.
</pre>
<p><strong>Example 2:</strong></p>
<img alt="" src="https://assets.leetcode.com/uploads/2020/12/03/tree.png" style="width: 234px; height: 241px;" />
<pre>
<strong>Input:</strong> pairs = [[1,2],[2,3],[1,3]]
<strong>Output:</strong> 2
<strong>Explanation:</strong> There are multiple valid rooted trees. Three of them are shown in the above figures.
</pre>
<p><strong>Example 3:</strong></p>
<pre>
<strong>Input:</strong> pairs = [[1,2],[2,3],[2,4],[1,5]]
<strong>Output:</strong> 0
<strong>Explanation:</strong> There are no valid rooted trees.</pre>
<p>&nbsp;</p>
<p><strong>Constraints:</strong></p>
<ul>
<li><code>1 &lt;= pairs.length &lt;= 10<sup>5</sup></code></li>
<li><code>1 &lt;= x<sub>i </sub>&lt; y<sub>i</sub> &lt;= 500</code></li>
<li>The elements in <code>pairs</code> are unique.</li>
</ul>