mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-10-24 06:18:57 +08:00
53 lines
2.1 KiB
HTML
53 lines
2.1 KiB
HTML
<p>存在一个未知数组需要你进行还原,给你一个整数 <code>n</code> 表示该数组的长度。另给你一个数组 <code>sums</code> ,由未知数组中全部 <code>2<sup>n</sup></code> 个 <strong>子集的和</strong> 组成(子集中的元素没有特定的顺序)。</p>
|
||
|
||
<p>返回一个长度为 <code>n</code> 的数组<em> </em><code>ans</code><em> </em>表示还原得到的未知数组。如果存在 <strong>多种</strong> 答案,只需返回其中 <strong>任意一个</strong> 。</p>
|
||
|
||
<p>如果可以由数组 <code>arr</code> 删除部分元素(也可能不删除或全删除)得到数组 <code>sub</code> ,那么数组 <code>sub</code> 就是数组 <code>arr</code> 的一个<strong> 子集</strong> 。<code>sub</code> 的元素之和就是 <code>arr</code> 的一个 <strong>子集的和</strong> 。一个空数组的元素之和为 <code>0</code> 。</p>
|
||
|
||
<p><strong>注意:</strong>生成的测试用例将保证至少存在一个正确答案。</p>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>示例 1:</strong></p>
|
||
|
||
<pre>
|
||
<strong>输入:</strong>n = 3, sums = [-3,-2,-1,0,0,1,2,3]
|
||
<strong>输出:</strong>[1,2,-3]
|
||
<strong>解释:</strong>[1,2,-3] 能够满足给出的子集的和:
|
||
- []:和是 0
|
||
- [1]:和是 1
|
||
- [2]:和是 2
|
||
- [1,2]:和是 3
|
||
- [-3]:和是 -3
|
||
- [1,-3]:和是 -2
|
||
- [2,-3]:和是 -1
|
||
- [1,2,-3]:和是 0
|
||
注意,[1,2,-3] 的任何排列和 [-1,-2,3] 的任何排列都会被视作正确答案。
|
||
</pre>
|
||
|
||
<p><strong>示例 2:</strong></p>
|
||
|
||
<pre>
|
||
<strong>输入:</strong>n = 2, sums = [0,0,0,0]
|
||
<strong>输出:</strong>[0,0]
|
||
<strong>解释:</strong>唯一的正确答案是 [0,0] 。
|
||
</pre>
|
||
|
||
<p><strong>示例 3:</strong></p>
|
||
|
||
<pre>
|
||
<strong>输入:</strong>n = 4, sums = [0,0,5,5,4,-1,4,9,9,-1,4,3,4,8,3,8]
|
||
<strong>输出:</strong>[0,-1,4,5]
|
||
<strong>解释:</strong>[0,-1,4,5] 能够满足给出的子集的和。
|
||
</pre>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>提示:</strong></p>
|
||
|
||
<ul>
|
||
<li><code>1 <= n <= 15</code></li>
|
||
<li><code>sums.length == 2<sup>n</sup></code></li>
|
||
<li><code>-10<sup>4</sup> <= sums[i] <= 10<sup>4</sup></code></li>
|
||
</ul>
|