mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-25 17:50:26 +08:00
74 lines
5.0 KiB
HTML
74 lines
5.0 KiB
HTML
<p>Given a string <code>s</code> and an integer <code>k</code>, partition <code>s</code> into <code>k</code> <strong><span data-keyword="substring-nonempty">substrings</span></strong> such that the letter changes needed to make each substring a <strong>semi-palindrome</strong> are minimized.</p>
|
||
|
||
<p>Return the <em><strong>minimum</strong> number of letter changes</em> required<em>.</em></p>
|
||
|
||
<p>A <strong>semi-palindrome</strong> is a special type of string that can be divided into <strong><span data-keyword="palindrome">palindromes</span></strong> based on a repeating pattern. To check if a string is a semi-palindrome:</p>
|
||
|
||
<ol>
|
||
<li>Choose a positive divisor <code>d</code> of the string's length. <code>d</code> can range from <code>1</code> up to, but not including, the string's length. For a string of length <code>1</code>, it does not have a valid divisor as per this definition, since the only divisor is its length, which is not allowed.</li>
|
||
<li>For a given divisor <code>d</code>, divide the string into groups where each group contains characters from the string that follow a repeating pattern of length <code>d</code>. Specifically, the first group consists of characters at positions <code>1</code>, <code>1 + d</code>, <code>1 + 2d</code>, and so on; the second group includes characters at positions <code>2</code>, <code>2 + d</code>, <code>2 + 2d</code>, etc.</li>
|
||
<li>The string is considered a semi-palindrome if each of these groups forms a palindrome.</li>
|
||
</ol>
|
||
|
||
<p>Consider the string <code>"abcabc"</code>:</p>
|
||
|
||
<ul>
|
||
<li>The length of <code>"abcabc"</code> is <code>6</code>. Valid divisors are <code>1</code>, <code>2</code>, and <code>3</code>.</li>
|
||
<li>For <code>d = 1</code>: The entire string <code>"abcabc"</code> forms one group. Not a palindrome.</li>
|
||
<li>For <code>d = 2</code>:
|
||
<ul>
|
||
<li>Group 1 (positions <code>1, 3, 5</code>): <code>"acb"</code></li>
|
||
<li>Group 2 (positions <code>2, 4, 6</code>): <code>"bac"</code></li>
|
||
<li>Neither group forms a palindrome.</li>
|
||
</ul>
|
||
</li>
|
||
<li>For <code>d = 3</code>:
|
||
<ul>
|
||
<li>Group 1 (positions <code>1, 4</code>): <code>"aa"</code></li>
|
||
<li>Group 2 (positions <code>2, 5</code>): <code>"bb"</code></li>
|
||
<li>Group 3 (positions <code>3, 6</code>): <code>"cc"</code></li>
|
||
<li>All groups form palindromes. Therefore, <code>"abcabc"</code> is a semi-palindrome.</li>
|
||
</ul>
|
||
</li>
|
||
</ul>
|
||
|
||
<p> </p>
|
||
<p><strong class="example">Example 1: </strong></p>
|
||
|
||
<div class="example-block" style="border-color: var(--border-tertiary); border-left-width: 2px; color: var(--text-secondary); font-size: .875rem; margin-bottom: 1rem; margin-top: 1rem; overflow: visible; padding-left: 1rem;">
|
||
<p><strong>Input: </strong> <span class="example-io" style="font-family: Menlo,sans-serif; font-size: 0.85rem;"> s = "abcac", k = 2 </span></p>
|
||
|
||
<p><strong>Output: </strong> <span class="example-io" style="font-family: Menlo,sans-serif; font-size: 0.85rem;"> 1 </span></p>
|
||
|
||
<p><strong>Explanation: </strong> Divide <code>s</code> into <code>"ab"</code> and <code>"cac"</code>. <code>"cac"</code> is already semi-palindrome. Change <code>"ab"</code> to <code>"aa"</code>, it becomes semi-palindrome with <code>d = 1</code>.</p>
|
||
</div>
|
||
|
||
<p><strong class="example">Example 2: </strong></p>
|
||
|
||
<div class="example-block" style="border-color: var(--border-tertiary); border-left-width: 2px; color: var(--text-secondary); font-size: .875rem; margin-bottom: 1rem; margin-top: 1rem; overflow: visible; padding-left: 1rem;">
|
||
<p><strong>Input: </strong> <span class="example-io" style="font-family: Menlo,sans-serif; font-size: 0.85rem;"> s = "abcdef", k = 2 </span></p>
|
||
|
||
<p><strong>Output: </strong> <span class="example-io" style="font-family: Menlo,sans-serif; font-size: 0.85rem;"> 2 </span></p>
|
||
|
||
<p><strong>Explanation: </strong> Divide <code>s</code> into substrings <code>"abc"</code> and <code>"def"</code>. Each needs one change to become semi-palindrome.</p>
|
||
</div>
|
||
|
||
<p><strong class="example">Example 3: </strong></p>
|
||
|
||
<div class="example-block" style="border-color: var(--border-tertiary); border-left-width: 2px; color: var(--text-secondary); font-size: .875rem; margin-bottom: 1rem; margin-top: 1rem; overflow: visible; padding-left: 1rem;">
|
||
<p><strong>Input: </strong> <span class="example-io" style="font-family: Menlo,sans-serif; font-size: 0.85rem;"> s = "aabbaa", k = 3 </span></p>
|
||
|
||
<p><strong>Output: </strong> <span class="example-io" style="font-family: Menlo,sans-serif; font-size: 0.85rem;"> 0 </span></p>
|
||
|
||
<p><strong>Explanation: </strong> Divide <code>s</code> into substrings <code>"aa"</code>, <code>"bb"</code> and <code>"aa"</code>. All are already semi-palindromes.</p>
|
||
</div>
|
||
|
||
<p> </p>
|
||
<p><strong>Constraints:</strong></p>
|
||
|
||
<ul>
|
||
<li><code>2 <= s.length <= 200</code></li>
|
||
<li><code>1 <= k <= s.length / 2</code></li>
|
||
<li><code>s</code> contains only lowercase English letters.</li>
|
||
</ul>
|