mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-11 02:58:13 +08:00
70 lines
3.7 KiB
HTML
70 lines
3.7 KiB
HTML
|
<p>You are given two <strong>1-indexed</strong> integer arrays, <code>nums</code> and, <code>changeIndices</code>, having lengths <code>n</code> and <code>m</code>, respectively.</p>
|
||
|
|
||
|
<p>Initially, all indices in <code>nums</code> are unmarked. Your task is to mark <strong>all</strong> indices in <code>nums</code>.</p>
|
||
|
|
||
|
<p>In each second, <code>s</code>, in order from <code>1</code> to <code>m</code> (<strong>inclusive</strong>), you can perform <strong>one</strong> of the following operations:</p>
|
||
|
|
||
|
<ul>
|
||
|
<li>Choose an index <code>i</code> in the range <code>[1, n]</code> and <strong>decrement</strong> <code>nums[i]</code> by <code>1</code>.</li>
|
||
|
<li>If <code>nums[changeIndices[s]]</code> is <strong>equal</strong> to <code>0</code>, <strong>mark</strong> the index <code>changeIndices[s]</code>.</li>
|
||
|
<li>Do nothing.</li>
|
||
|
</ul>
|
||
|
|
||
|
<p>Return <em>an integer denoting the <strong>earliest second</strong> in the range </em><code>[1, m]</code><em> when <strong>all</strong> indices in </em><code>nums</code><em> can be marked by choosing operations optimally, or </em><code>-1</code><em> if it is impossible.</em></p>
|
||
|
|
||
|
<p> </p>
|
||
|
<p><strong class="example">Example 1:</strong></p>
|
||
|
|
||
|
<pre>
|
||
|
<strong>Input:</strong> nums = [2,2,0], changeIndices = [2,2,2,2,3,2,2,1]
|
||
|
<strong>Output:</strong> 8
|
||
|
<strong>Explanation:</strong> In this example, we have 8 seconds. The following operations can be performed to mark all indices:
|
||
|
Second 1: Choose index 1 and decrement nums[1] by one. nums becomes [1,2,0].
|
||
|
Second 2: Choose index 1 and decrement nums[1] by one. nums becomes [0,2,0].
|
||
|
Second 3: Choose index 2 and decrement nums[2] by one. nums becomes [0,1,0].
|
||
|
Second 4: Choose index 2 and decrement nums[2] by one. nums becomes [0,0,0].
|
||
|
Second 5: Mark the index changeIndices[5], which is marking index 3, since nums[3] is equal to 0.
|
||
|
Second 6: Mark the index changeIndices[6], which is marking index 2, since nums[2] is equal to 0.
|
||
|
Second 7: Do nothing.
|
||
|
Second 8: Mark the index changeIndices[8], which is marking index 1, since nums[1] is equal to 0.
|
||
|
Now all indices have been marked.
|
||
|
It can be shown that it is not possible to mark all indices earlier than the 8th second.
|
||
|
Hence, the answer is 8.
|
||
|
</pre>
|
||
|
|
||
|
<p><strong class="example">Example 2:</strong></p>
|
||
|
|
||
|
<pre>
|
||
|
<strong>Input:</strong> nums = [1,3], changeIndices = [1,1,1,2,1,1,1]
|
||
|
<strong>Output:</strong> 6
|
||
|
<strong>Explanation:</strong> In this example, we have 7 seconds. The following operations can be performed to mark all indices:
|
||
|
Second 1: Choose index 2 and decrement nums[2] by one. nums becomes [1,2].
|
||
|
Second 2: Choose index 2 and decrement nums[2] by one. nums becomes [1,1].
|
||
|
Second 3: Choose index 2 and decrement nums[2] by one. nums becomes [1,0].
|
||
|
Second 4: Mark the index changeIndices[4], which is marking index 2, since nums[2] is equal to 0.
|
||
|
Second 5: Choose index 1 and decrement nums[1] by one. nums becomes [0,0].
|
||
|
Second 6: Mark the index changeIndices[6], which is marking index 1, since nums[1] is equal to 0.
|
||
|
Now all indices have been marked.
|
||
|
It can be shown that it is not possible to mark all indices earlier than the 6th second.
|
||
|
Hence, the answer is 6.
|
||
|
</pre>
|
||
|
|
||
|
<p><strong class="example">Example 3:</strong></p>
|
||
|
|
||
|
<pre>
|
||
|
<strong>Input:</strong> nums = [0,1], changeIndices = [2,2,2]
|
||
|
<strong>Output:</strong> -1
|
||
|
<strong>Explanation:</strong> In this example, it is impossible to mark all indices because index 1 isn't in changeIndices.
|
||
|
Hence, the answer is -1.
|
||
|
</pre>
|
||
|
|
||
|
<p> </p>
|
||
|
<p><strong>Constraints:</strong></p>
|
||
|
|
||
|
<ul>
|
||
|
<li><code>1 <= n == nums.length <= 2000</code></li>
|
||
|
<li><code>0 <= nums[i] <= 10<sup>9</sup></code></li>
|
||
|
<li><code>1 <= m == changeIndices.length <= 2000</code></li>
|
||
|
<li><code>1 <= changeIndices[i] <= n</code></li>
|
||
|
</ul>
|