mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-10-24 14:28:56 +08:00
40 lines
1.7 KiB
HTML
40 lines
1.7 KiB
HTML
<p>Given a string <code>num</code> that contains only digits and an integer <code>target</code>, return <em><strong>all possibilities</strong> to insert the binary operators </em><code>'+'</code><em>, </em><code>'-'</code><em>, and/or </em><code>'*'</code><em> between the digits of </em><code>num</code><em> so that the resultant expression evaluates to the </em><code>target</code><em> value</em>.</p>
|
|
|
|
<p>Note that operands in the returned expressions <strong>should not</strong> contain leading zeros.</p>
|
|
|
|
<p><strong>Note</strong> that a number can contain multiple digits.</p>
|
|
|
|
<p> </p>
|
|
<p><strong class="example">Example 1:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input:</strong> num = "123", target = 6
|
|
<strong>Output:</strong> ["1*2*3","1+2+3"]
|
|
<strong>Explanation:</strong> Both "1*2*3" and "1+2+3" evaluate to 6.
|
|
</pre>
|
|
|
|
<p><strong class="example">Example 2:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input:</strong> num = "232", target = 8
|
|
<strong>Output:</strong> ["2*3+2","2+3*2"]
|
|
<strong>Explanation:</strong> Both "2*3+2" and "2+3*2" evaluate to 8.
|
|
</pre>
|
|
|
|
<p><strong class="example">Example 3:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input:</strong> num = "3456237490", target = 9191
|
|
<strong>Output:</strong> []
|
|
<strong>Explanation:</strong> There are no expressions that can be created from "3456237490" to evaluate to 9191.
|
|
</pre>
|
|
|
|
<p> </p>
|
|
<p><strong>Constraints:</strong></p>
|
|
|
|
<ul>
|
|
<li><code>1 <= num.length <= 10</code></li>
|
|
<li><code>num</code> consists of only digits.</li>
|
|
<li><code>-2<sup>31</sup> <= target <= 2<sup>31</sup> - 1</code></li>
|
|
</ul>
|