1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-25 17:50:26 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/回文串重新排列查询 [palindrome-rearrangement-queries].html
2024-01-09 10:57:06 +08:00

81 lines
4.6 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<p>给你一个长度为 <strong>偶数</strong>&nbsp;<code>n</code>&nbsp;,下标从 <strong>0</strong>&nbsp;开始的字符串&nbsp;<code>s</code>&nbsp;</p>
<p>同时给你一个下标从 <strong>0</strong>&nbsp;开始的二维整数数组&nbsp;<code>queries</code>&nbsp;,其中&nbsp;<code>queries[i] = [a<sub>i</sub>, b<sub>i</sub>, c<sub>i</sub>, d<sub>i</sub>]</code>&nbsp;</p>
<p>对于每个查询&nbsp;<code>i</code>&nbsp;,你需要执行以下操作:</p>
<ul>
<li>将下标在范围&nbsp;<code>0 &lt;= a<sub>i</sub> &lt;= b<sub>i</sub> &lt; n / 2</code>&nbsp;内的&nbsp;<strong>子字符串</strong>&nbsp;<code>s[a<sub>i</sub>:b<sub>i</sub>]</code>&nbsp;中的字符重新排列。</li>
<li>将下标在范围 <code>n / 2 &lt;= c<sub>i</sub> &lt;= d<sub>i</sub> &lt; n</code>&nbsp;内的 <strong>子字符串</strong>&nbsp;<code>s[c<sub>i</sub>:d<sub>i</sub>]</code>&nbsp;中的字符重新排列。</li>
</ul>
<p>对于每个查询,你的任务是判断执行操作后能否让 <code>s</code>&nbsp;变成一个 <strong>回文串</strong></p>
<p>每个查询与其他查询都是 <strong>独立的</strong>&nbsp;</p>
<p>请你返回一个下标从 <strong>0</strong>&nbsp;开始的数组<em>&nbsp;</em><code>answer</code>&nbsp;,如果第&nbsp;<code>i</code>&nbsp;个查询执行操作后,可以将&nbsp;<code>s</code>&nbsp;变为一个回文串,那么<em>&nbsp;</em><code>answer[i] =&nbsp;true</code>,否则为<em>&nbsp;</em><code>false</code>&nbsp;</p>
<ul>
<li><strong>子字符串</strong>&nbsp;指的是一个字符串中一段连续的字符序列。</li>
<li><code>s[x:y]</code>&nbsp;表示 <code>s</code>&nbsp;中从下标 <code>x</code>&nbsp;<code>y</code>&nbsp;且两个端点 <strong>都包含</strong>&nbsp;的子字符串。</li>
</ul>
<p>&nbsp;</p>
<p><strong class="example">示例 1</strong></p>
<pre>
<b>输入:</b>s = "abcabc", queries = [[1,1,3,5],[0,2,5,5]]
<b>输出:</b>[true,true]
<b>解释:</b>这个例子中,有 2 个查询:
第一个查询:
- a<sub>0</sub> = 1, b<sub>0</sub> = 1, c<sub>0</sub> = 3, d<sub>0</sub> = 5
- 你可以重新排列 s[1:1] =&gt; a<em><strong>b</strong></em>cabc 和 s[3:5] =&gt; abc<em><strong>abc</strong></em>&nbsp;
- 为了让 s 变为回文串s[3:5] 可以重新排列得到 =&gt; abc<strong><em>cba </em></strong>
- 现在 s 是一个回文串。所以 answer[0] = true 。
第二个查询:
- a<sub>1</sub> = 0, b<sub>1</sub> = 2, c<sub>1</sub> = 5, d<sub>1</sub> = 5.
- 你可以重新排列 s[0:2] =&gt; <em><strong>abc</strong></em>abc 和 s[5:5] =&gt; abcab<strong><em>c</em></strong>&nbsp;
- 为了让 s 变为回文串s[0:2] 可以重新排列得到 =&gt; <em><strong>cba</strong></em>abc 。
- 现在 s 是一个回文串,所以 answer[1] = true 。
</pre>
<p><strong class="example">示例 2</strong></p>
<pre>
<b>输入:</b>s = "abbcdecbba", queries = [[0,2,7,9]]
<b>输出:</b>[false]
<b>解释:</b>这个示例中,只有一个查询。
a<sub>0</sub> = 0, b<sub>0</sub> = 2, c<sub>0</sub> = 7, d<sub>0</sub> = 9.
你可以重新排列 s[0:2] =&gt; <em><strong>abb</strong></em>cdecbba 和 s[7:9] =&gt; abbcdec<em><strong>bba</strong></em>&nbsp;
无法通过重新排列这些子字符串使 s 变为一个回文串,因为 s[3:6] 不是一个回文串。
所以 answer[0] = false 。</pre>
<p><strong class="example">示例 3</strong></p>
<pre>
<b>输入:</b>s = "acbcab", queries = [[1,2,4,5]]
<b>输出:</b>[true]
<strong>解释:</strong>这个示例中,只有一个查询。
a<sub>0</sub> = 1, b<sub>0</sub> = 2, c<sub>0</sub> = 4, d<sub>0</sub> = 5.
你可以重新排列 s[1:2] =&gt; a<em><strong>cb</strong></em>cab 和 s[4:5] =&gt; acbc<strong><em>ab</em></strong>&nbsp;
为了让 s 变为回文串s[1:2] 可以重新排列得到 =&gt; a<em><strong>bc</strong></em>cab<code>&nbsp;</code>
然后 s[4:5] 重新排列得到 abcc<em><strong>ba</strong></em>&nbsp;
现在 s 是一个回文串,所以 answer[0] = true 。</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>2 &lt;= n == s.length &lt;= 10<sup>5</sup></code></li>
<li><code>1 &lt;= queries.length &lt;= 10<sup>5</sup></code></li>
<li><code>queries[i].length == 4</code></li>
<li><code>a<sub>i</sub> == queries[i][0], b<sub>i</sub> == queries[i][1]</code></li>
<li><code>c<sub>i</sub> == queries[i][2], d<sub>i</sub> == queries[i][3]</code></li>
<li><code>0 &lt;= a<sub>i</sub> &lt;= b<sub>i</sub> &lt; n / 2</code></li>
<li><code>n / 2 &lt;= c<sub>i</sub> &lt;= d<sub>i</sub> &lt; n </code></li>
<li><code>n</code>&nbsp;是一个偶数。</li>
<li><code>s</code> 只包含小写英文字母。</li>
</ul>