回文串重新排列查询
将下标在范围
0 <= ai <= bi < n / 2内的 子字符串s[ai:bi]中的字符重新排列。将下标在范围
n / 2 <= ci <= di < n内的 子字符串s[ci:di]中的字符重新排列。子字符串 指的是一个字符串中一段连续的字符序列。
s[x:y]表示s中从下标x到y且两个端点 都包含 的子字符串。a0 = 1, b0 = 1, c0 = 3, d0 = 5
你可以重新排列 s[1:1] => abcabc 和 s[3:5] => abcabc 。
为了让 s 变为回文串,s[3:5] 可以重新排列得到 => abccba 。
现在 s 是一个回文串。所以 answer[0] = true 。
a1 = 0, b1 = 2, c1 = 5, d1 = 5.
你可以重新排列 s[0:2] => abcabc 和 s[5:5] => abcabc 。
为了让 s 变为回文串,s[0:2] 可以重新排列得到 => cbaabc 。
现在 s 是一个回文串,所以 answer[1] = true 。
2 <= n == s.length <= 10^51 <= queries.length <= 10^5queries[i].length == 4ai == queries[i][0], bi == queries[i][1]ci == queries[i][2], di == queries[i][3]0 <= ai <= bi < n / 2n / 2 <= ci <= di < nn是一个偶数。s只包含小写英文字母。
给你一个长度为 偶数 n ,下标从 0 开始的字符串 s 。
同时给你一个下标从 0 开始的二维整数数组 queries ,其中 queries[i] = [ai, bi, ci, di] 。
对于每个查询 i ,你需要执行以下操作:
对于每个查询,你的任务是判断执行操作后能否让 s 变成一个 回文串 。
每个查询与其他查询都是 独立的 。
请你返回一个下标从 0 开始的数组 answer ,如果第 i 个查询执行操作后,可以将 s 变为一个回文串,那么 answer[i] = true,否则为 false 。
示例 1:
```txt
输入:s = "abcabc", queries = [[1,1,3,5],[0,2,5,5]]
输出:[true,true]
解释:这个例子中,有 2 个查询:
第一个查询:
第二个查询:
```
示例 2:
```txt
输入:s = "abbcdecbba", queries = [[0,2,7,9]]
输出:[false]
解释:这个示例中,只有一个查询。
a0 = 0, b0 = 2, c0 = 7, d0 = 9.
你可以重新排列 s[0:2] => abbcdecbba 和 s[7:9] => abbcdecbba 。
无法通过重新排列这些子字符串使 s 变为一个回文串,因为 s[3:6] 不是一个回文串。
所以 answer[0] = false 。
```
示例 3:
```txt
输入:s = "acbcab", queries = [[1,2,4,5]]
输出:[true]
解释:这个示例中,只有一个查询。
a0 = 1, b0 = 2, c0 = 4, d0 = 5.
你可以重新排列 s[1:2] => acbcab 和 s[4:5] => acbcab 。
为了让 s 变为回文串,s[1:2] 可以重新排列得到 => abccab 。
然后 s[4:5] 重新排列得到 abccba 。
现在 s 是一个回文串,所以 answer[0] = true 。
```
提示:


