mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 14:58:56 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			50 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>You are given two strings <code>s</code> and <code>t</code> of equal length <code>n</code>. You can perform the following operation on the string <code>s</code>:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li>Remove a <strong>suffix</strong> of <code>s</code> of length <code>l</code> where <code>0 < l < n</code> and append it at the start of <code>s</code>.<br />
 | |
| 	For example, let <code>s = 'abcd'</code> then in one operation you can remove the suffix <code>'cd'</code> and append it in front of <code>s</code> making <code>s = 'cdab'</code>.</li>
 | |
| </ul>
 | |
| 
 | |
| <p>You are also given an integer <code>k</code>. Return <em>the number of ways in which </em><code>s</code> <em>can be transformed into </em><code>t</code><em> in <strong>exactly</strong> </em><code>k</code><em> operations.</em></p>
 | |
| 
 | |
| <p>Since the answer can be large, return it <strong>modulo</strong> <code>10<sup>9</sup> + 7</code>.</p>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong class="example">Example 1:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> s = "abcd", t = "cdab", k = 2
 | |
| <strong>Output:</strong> 2
 | |
| <strong>Explanation:</strong> 
 | |
| First way:
 | |
| In first operation, choose suffix from index = 3, so resulting s = "dabc".
 | |
| In second operation, choose suffix from index = 3, so resulting s = "cdab".
 | |
| 
 | |
| Second way:
 | |
| In first operation, choose suffix from index = 1, so resulting s = "bcda".
 | |
| In second operation, choose suffix from index = 1, so resulting s = "cdab".
 | |
| </pre>
 | |
| 
 | |
| <p><strong class="example">Example 2:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input:</strong> s = "ababab", t = "ababab", k = 1
 | |
| <strong>Output:</strong> 2
 | |
| <strong>Explanation:</strong> 
 | |
| First way:
 | |
| Choose suffix from index = 2, so resulting s = "ababab".
 | |
| 
 | |
| Second way:
 | |
| Choose suffix from index = 4, so resulting s = "ababab".
 | |
| </pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>2 <= s.length <= 5 * 10<sup>5</sup></code></li>
 | |
| 	<li><code>1 <= k <= 10<sup>15</sup></code></li>
 | |
| 	<li><code>s.length == t.length</code></li>
 | |
| 	<li><code>s</code> and <code>t</code> consist of only lowercase English alphabets.</li>
 | |
| </ul>
 |