<p>You are given a string <code>s</code> and a <strong>positive</strong> integer <code>k</code>.</p> <p>Select a set of <strong>non-overlapping</strong> substrings from the string <code>s</code> that satisfy the following conditions:</p> <ul> <li>The <strong>length</strong> of each substring is <strong>at least</strong> <code>k</code>.</li> <li>Each substring is a <strong>palindrome</strong>.</li> </ul> <p>Return <em>the <strong>maximum</strong> number of substrings in an optimal selection</em>.</p> <p>A <strong>substring</strong> is a contiguous sequence of characters within a string.</p> <p> </p> <p><strong class="example">Example 1:</strong></p> <pre> <strong>Input:</strong> s = "abaccdbbd", k = 3 <strong>Output:</strong> 2 <strong>Explanation:</strong> We can select the substrings underlined in s = "<u><strong>aba</strong></u>cc<u><strong>dbbd</strong></u>". Both "aba" and "dbbd" are palindromes and have a length of at least k = 3. It can be shown that we cannot find a selection with more than two valid substrings. </pre> <p><strong class="example">Example 2:</strong></p> <pre> <strong>Input:</strong> s = "adbcda", k = 2 <strong>Output:</strong> 0 <strong>Explanation:</strong> There is no palindrome substring of length at least 2 in the string. </pre> <p> </p> <p><strong>Constraints:</strong></p> <ul> <li><code>1 <= k <= s.length <= 2000</code></li> <li><code>s</code> consists of lowercase English letters.</li> </ul>