mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 23:08:57 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			70 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			3.5 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>Set <code>nums[changeIndices[s]]</code> to any <strong>non-negative</strong> value.</li>
 | |
| 	<li>Choose an index <code>i</code> in the range <code>[1, n]</code>, where <code>nums[i]</code> is <strong>equal</strong> to <code>0</code>, and <strong>mark</strong> index <code>i</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 = [3,2,3], changeIndices = [1,3,2,2,2,2,3]
 | |
| <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: Set nums[changeIndices[1]] to 0. nums becomes [0,2,3].
 | |
| Second 2: Set nums[changeIndices[2]] to 0. nums becomes [0,2,0].
 | |
| Second 3: Set nums[changeIndices[3]] to 0. nums becomes [0,0,0].
 | |
| Second 4: Mark index 1, since nums[1] is equal to 0.
 | |
| Second 5: Mark index 2, since nums[2] is equal to 0.
 | |
| Second 6: Mark index 3, since nums[3] 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 2:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> nums = [0,0,1,2], changeIndices = [1,2,1,2,1,2,1,2]
 | |
| <strong>Output:</strong> 7
 | |
| <strong>Explanation:</strong> In this example, we have 8 seconds. The following operations can be performed to mark all indices:
 | |
| Second 1: Mark index 1, since nums[1] is equal to 0.
 | |
| Second 2: Mark index 2, since nums[2] is equal to 0.
 | |
| Second 3: Decrement index 4 by one. nums becomes [0,0,1,1].
 | |
| Second 4: Decrement index 4 by one. nums becomes [0,0,1,0].
 | |
| Second 5: Decrement index 3 by one. nums becomes [0,0,0,0].
 | |
| Second 6: Mark index 3, since nums[3] is equal to 0.
 | |
| Second 7: Mark index 4, since nums[4] 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 7th second.
 | |
| Hence, the answer is 7.
 | |
| </pre>
 | |
| 
 | |
| <p><strong class="example">Example 3:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> nums = [1,2,3], changeIndices = [1,2,3]
 | |
| <strong>Output:</strong> -1
 | |
| <strong>Explanation: </strong>In this example, it can be shown that it is impossible to mark all indices, as we don't have enough seconds. 
 | |
| Hence, the answer is -1.
 | |
| </pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>1 <= n == nums.length <= 5000</code></li>
 | |
| 	<li><code>0 <= nums[i] <= 10<sup>9</sup></code></li>
 | |
| 	<li><code>1 <= m == changeIndices.length <= 5000</code></li>
 | |
| 	<li><code>1 <= changeIndices[i] <= n</code></li>
 | |
| </ul>
 |