mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-23 13:58:56 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			80 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>You are given a string <code>source</code> of size <code>n</code>, a string <code>pattern</code> that is a <span data-keyword="subsequence-string">subsequence</span> of <code>source</code>, and a <strong>sorted</strong> integer array <code>targetIndices</code> that contains <strong>distinct</strong> numbers in the range <code>[0, n - 1]</code>.</p>
 | |
| 
 | |
| <p>We define an <strong>operation</strong> as removing a character at an index <code>idx</code> from <code>source</code> such that:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>idx</code> is an element of <code>targetIndices</code>.</li>
 | |
| 	<li><code>pattern</code> remains a <span data-keyword="subsequence-string">subsequence</span> of <code>source</code> after removing the character.</li>
 | |
| </ul>
 | |
| 
 | |
| <p>Performing an operation <strong>does not</strong> change the indices of the other characters in <code>source</code>. For example, if you remove <code>'c'</code> from <code>"acb"</code>, the character at index 2 would still be <code>'b'</code>.</p>
 | |
| 
 | |
| <p>Return the <strong>maximum</strong> number of <em>operations</em> that can be performed.</p>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong class="example">Example 1:</strong></p>
 | |
| 
 | |
| <div class="example-block">
 | |
| <p><strong>Input:</strong> <span class="example-io">source = "abbaa", pattern = "aba", </span>targetIndices<span class="example-io"> = [0,1,2]</span></p>
 | |
| 
 | |
| <p><strong>Output:</strong> 1</p>
 | |
| 
 | |
| <p><strong>Explanation:</strong></p>
 | |
| 
 | |
| <p>We can't remove <code>source[0]</code> but we can do either of these two operations:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li>Remove <code>source[1]</code>, so that <code>source</code> becomes <code>"a_baa"</code>.</li>
 | |
| 	<li>Remove <code>source[2]</code>, so that <code>source</code> becomes <code>"ab_aa"</code>.</li>
 | |
| </ul>
 | |
| </div>
 | |
| 
 | |
| <p><strong class="example">Example 2:</strong></p>
 | |
| 
 | |
| <div class="example-block">
 | |
| <p><strong>Input:</strong> <span class="example-io">source = "bcda", pattern = "d", </span>targetIndices<span class="example-io"> = [0,3]</span></p>
 | |
| 
 | |
| <p><strong>Output:</strong> 2</p>
 | |
| 
 | |
| <p><strong>Explanation:</strong></p>
 | |
| 
 | |
| <p>We can remove <code>source[0]</code> and <code>source[3]</code> in two operations.</p>
 | |
| </div>
 | |
| 
 | |
| <p><strong class="example">Example 3:</strong></p>
 | |
| 
 | |
| <div class="example-block">
 | |
| <p><strong>Input:</strong> <span class="example-io">source = "dda", pattern = "dda", </span>targetIndices<span class="example-io"> = [0,1,2]</span></p>
 | |
| 
 | |
| <p><strong>Output:</strong> <span class="example-io">0</span></p>
 | |
| 
 | |
| <p><strong>Explanation:</strong></p>
 | |
| 
 | |
| <p>We can't remove any character from <code>source</code>.</p>
 | |
| </div>
 | |
| 
 | |
| <p><strong class="example">Example 4:</strong></p>
 | |
| 
 | |
| <div class="example-block">
 | |
| <p><strong>Input:</strong> <span class="example-io">source = </span>"yeyeykyded"<span class="example-io">, pattern = </span>"yeyyd"<span class="example-io">, </span>targetIndices<span class="example-io"> = </span>[0,2,3,4]</p>
 | |
| 
 | |
| <p><strong>Output:</strong> 2</p>
 | |
| 
 | |
| <p><strong>Explanation:</strong></p>
 | |
| 
 | |
| <p>We can remove <code>source[2]</code> and <code>source[3]</code> in two operations.</p>
 | |
| </div>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>1 <= n == source.length <= 3 * 10<sup>3</sup></code></li>
 | |
| 	<li><code>1 <= pattern.length <= n</code></li>
 | |
| 	<li><code>1 <= targetIndices.length <= n</code></li>
 | |
| 	<li><code>targetIndices</code> is sorted in ascending order.</li>
 | |
| 	<li>The input is generated such that <code>targetIndices</code> contains distinct elements in the range <code>[0, n - 1]</code>.</li>
 | |
| 	<li><code>source</code> and <code>pattern</code> consist only of lowercase English letters.</li>
 | |
| 	<li>The input is generated such that <code>pattern</code> appears as a subsequence in <code>source</code>.</li>
 | |
| </ul>
 |