mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-10-24 06:18:57 +08:00
47 lines
2.2 KiB
HTML
47 lines
2.2 KiB
HTML
<p>给你一个下标从 <strong>0</strong> 开始的字符串 <code>str1</code> 和 <code>str2</code> 。</p>
|
||
|
||
<p>一次操作中,你选择 <code>str1</code> 中的若干下标。对于选中的每一个下标 <code>i</code> ,你将 <code>str1[i]</code> <strong>循环</strong> 递增,变成下一个字符。也就是说 <code>'a'</code> 变成 <code>'b'</code> ,<code>'b'</code> 变成 <code>'c'</code> ,以此类推,<code>'z'</code> 变成 <code>'a'</code> 。</p>
|
||
|
||
<p>如果执行以上操作 <strong>至多一次</strong> ,可以让 <code>str2</code> 成为 <code>str1</code> 的子序列,请你返回 <code>true</code> ,否则返回 <code>false</code> 。</p>
|
||
|
||
<p><b>注意:</b>一个字符串的子序列指的是从原字符串中删除一些(可以一个字符也不删)字符后,剩下字符按照原本先后顺序组成的新字符串。</p>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong class="example">示例 1:</strong></p>
|
||
|
||
<pre>
|
||
<b>输入:</b>str1 = "abc", str2 = "ad"
|
||
<b>输出:</b>true
|
||
<b>解释:</b>选择 str1 中的下标 2 。
|
||
将 str1[2] 循环递增,得到 'd' 。
|
||
因此,str1 变成 "abd" 且 str2 现在是一个子序列。所以返回 true 。</pre>
|
||
|
||
<p><strong class="example">示例 2:</strong></p>
|
||
|
||
<pre>
|
||
<b>输入:</b>str1 = "zc", str2 = "ad"
|
||
<b>输出:</b>true
|
||
<b>解释:</b>选择 str1 中的下标 0 和 1 。
|
||
将 str1[0] 循环递增得到 'a' 。
|
||
将 str1[1] 循环递增得到 'd' 。
|
||
因此,str1 变成 "ad" 且 str2 现在是一个子序列。所以返回 true 。</pre>
|
||
|
||
<p><strong class="example">示例 3:</strong></p>
|
||
|
||
<pre>
|
||
<b>输入:</b>str1 = "ab", str2 = "d"
|
||
<b>输出:</b>false
|
||
<b>解释:</b>这个例子中,没法在执行一次操作的前提下,将 str2 变为 str1 的子序列。
|
||
所以返回 false 。</pre>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>提示:</strong></p>
|
||
|
||
<ul>
|
||
<li><code>1 <= str1.length <= 10<sup>5</sup></code></li>
|
||
<li><code>1 <= str2.length <= 10<sup>5</sup></code></li>
|
||
<li><code>str1</code> 和 <code>str2</code> 只包含小写英文字母。</li>
|
||
</ul>
|