mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-10 18:48:13 +08:00
47 lines
2.3 KiB
HTML
47 lines
2.3 KiB
HTML
<p>You are given a string <code>s</code> that consists of only digits.</p>
|
||
|
||
<p>Check if we can split <code>s</code> into <strong>two or more non-empty substrings</strong> such that the <strong>numerical values</strong> of the substrings are in <strong>descending order</strong> and the <strong>difference</strong> between numerical values of every two <strong>adjacent</strong> <strong>substrings</strong> is equal to <code>1</code>.</p>
|
||
|
||
<ul>
|
||
<li>For example, the string <code>s = "0090089"</code> can be split into <code>["0090", "089"]</code> with numerical values <code>[90,89]</code>. The values are in descending order and adjacent values differ by <code>1</code>, so this way is valid.</li>
|
||
<li>Another example, the string <code>s = "001"</code> can be split into <code>["0", "01"]</code>, <code>["00", "1"]</code>, or <code>["0", "0", "1"]</code>. However all the ways are invalid because they have numerical values <code>[0,1]</code>, <code>[0,1]</code>, and <code>[0,0,1]</code> respectively, all of which are not in descending order.</li>
|
||
</ul>
|
||
|
||
<p>Return <code>true</code> <em>if it is possible to split</em> <code>s</code> <em>as described above</em><em>, or </em><code>false</code><em> otherwise.</em></p>
|
||
|
||
<p>A <strong>substring</strong> is a contiguous sequence of characters in a string.</p>
|
||
|
||
<p> </p>
|
||
<p><strong class="example">Example 1:</strong></p>
|
||
|
||
<pre>
|
||
<strong>Input:</strong> s = "1234"
|
||
<strong>Output:</strong> false
|
||
<strong>Explanation:</strong> There is no valid way to split s.
|
||
</pre>
|
||
|
||
<p><strong class="example">Example 2:</strong></p>
|
||
|
||
<pre>
|
||
<strong>Input:</strong> s = "050043"
|
||
<strong>Output:</strong> true
|
||
<strong>Explanation:</strong> s can be split into ["05", "004", "3"] with numerical values [5,4,3].
|
||
The values are in descending order with adjacent values differing by 1.
|
||
</pre>
|
||
|
||
<p><strong class="example">Example 3:</strong></p>
|
||
|
||
<pre>
|
||
<strong>Input:</strong> s = "9080701"
|
||
<strong>Output:</strong> false
|
||
<strong>Explanation:</strong> There is no valid way to split s.
|
||
</pre>
|
||
|
||
<p> </p>
|
||
<p><strong>Constraints:</strong></p>
|
||
|
||
<ul>
|
||
<li><code>1 <= s.length <= 20</code></li>
|
||
<li><code>s</code> only consists of digits.</li>
|
||
</ul>
|