mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-26 02:00:27 +08:00
61 lines
2.8 KiB
HTML
61 lines
2.8 KiB
HTML
<p>You are given a string <code>num</code>, representing a large integer, and an integer <code>k</code>.</p>
|
|
|
|
<p>We call some integer <strong>wonderful</strong> if it is a <strong>permutation</strong> of the digits in <code>num</code> and is <strong>greater in value</strong> than <code>num</code>. There can be many wonderful integers. However, we only care about the <strong>smallest-valued</strong> ones.</p>
|
|
|
|
<ul>
|
|
<li>For example, when <code>num = "5489355142"</code>:
|
|
|
|
<ul>
|
|
<li>The 1<sup>st</sup> smallest wonderful integer is <code>"5489355214"</code>.</li>
|
|
<li>The 2<sup>nd</sup> smallest wonderful integer is <code>"5489355241"</code>.</li>
|
|
<li>The 3<sup>rd</sup> smallest wonderful integer is <code>"5489355412"</code>.</li>
|
|
<li>The 4<sup>th</sup> smallest wonderful integer is <code>"5489355421"</code>.</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>Return <em>the <strong>minimum number of adjacent digit swaps</strong> that needs to be applied to </em><code>num</code><em> to reach the </em><code>k<sup>th</sup></code><em><strong> smallest wonderful</strong> integer</em>.</p>
|
|
|
|
<p>The tests are generated in such a way that <code>k<sup>th</sup></code> smallest wonderful integer exists.</p>
|
|
|
|
<p> </p>
|
|
<p><strong>Example 1:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input:</strong> num = "5489355142", k = 4
|
|
<strong>Output:</strong> 2
|
|
<strong>Explanation:</strong> The 4<sup>th</sup> smallest wonderful number is "5489355421". To get this number:
|
|
- Swap index 7 with index 8: "5489355<u>14</u>2" -> "5489355<u>41</u>2"
|
|
- Swap index 8 with index 9: "54893554<u>12</u>" -> "54893554<u>21</u>"
|
|
</pre>
|
|
|
|
<p><strong>Example 2:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input:</strong> num = "11112", k = 4
|
|
<strong>Output:</strong> 4
|
|
<strong>Explanation:</strong> The 4<sup>th</sup> smallest wonderful number is "21111". To get this number:
|
|
- Swap index 3 with index 4: "111<u>12</u>" -> "111<u>21</u>"
|
|
- Swap index 2 with index 3: "11<u>12</u>1" -> "11<u>21</u>1"
|
|
- Swap index 1 with index 2: "1<u>12</u>11" -> "1<u>21</u>11"
|
|
- Swap index 0 with index 1: "<u>12</u>111" -> "<u>21</u>111"
|
|
</pre>
|
|
|
|
<p><strong>Example 3:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input:</strong> num = "00123", k = 1
|
|
<strong>Output:</strong> 1
|
|
<strong>Explanation:</strong> The 1<sup>st</sup> smallest wonderful number is "00132". To get this number:
|
|
- Swap index 3 with index 4: "001<u>23</u>" -> "001<u>32</u>"
|
|
</pre>
|
|
|
|
<p> </p>
|
|
<p><strong>Constraints:</strong></p>
|
|
|
|
<ul>
|
|
<li><code>2 <= num.length <= 1000</code></li>
|
|
<li><code>1 <= k <= 1000</code></li>
|
|
<li><code>num</code> only consists of digits.</li>
|
|
</ul>
|