CF1650A.Deletions of Two Adjacent Letters

传统题 时间 2000 ms 内存 256 MiB 3 尝试 1 已通过 1 标签

Deletions of Two Adjacent Letters

题目描述

给定一个字符串 ss,其长度为奇数。字符串由小写拉丁字母组成。

只要字符串的长度大于 11,就可以对其进行如下操作:选择字符串 ss 中任意两个相邻的字母,并将它们从字符串中删除。例如,对于字符串 "lemma",一次操作后可以得到以下四个字符串中的任意一个:"mma"、"lma"、"lea" 或 "lem"。特别地,每次操作后,字符串的长度减少 22

形式化地,设字符串 ss 的形式为 s=s1s2sns=s_1s_2\dots s_nn>1n>1)。每次操作时,你可以选择任意下标 ii1i<n1 \le i < n),并将 ss 替换为 s1s2si1si+2sns_1s_2\dots s_{i-1}s_{i+2}\dots s_n

对于给定的字符串 ss 和字母 cc,判断是否存在一系列操作,使得最终 s=cs=c 成立?换句话说,是否存在一种操作顺序,使得过程结束时字符串长度为 11,且该字符为 cc

输入格式

输入的第一行包含一个整数 tt1t1031 \le t \le 10^3),表示测试用例的数量。

接下来是 tt 组测试数据。每组测试数据包含两行:

  • 第一行为字符串 ss,其长度为 114949 的奇数,且由小写拉丁字母组成;
  • 第二行为一个字符串,包含一个小写拉丁字母 cc

输出格式

对于每个测试用例,输出一行:

  • 如果可以通过操作将字符串 ss 变为 cc,则输出 YES;
  • 否则输出 NO。

你可以以任意大小写输出 YES 和 NO(例如 yEs、yes、Yes 和 YES 都被认为是肯定的回答)。

说明/提示

在第一个测试用例中,ss = "abcde",你需要得到 ss = "c"。第一次操作删除前两个字母,得到 ss = "cde"。第二次操作删除最后两个字母,得到期望的 ss = "c"。

在第三个测试用例中,ss = "x",要求得到 ss = "y"。显然,这是不可能的。

由 ChatGPT 4.1 翻译

样例

5
abcde
c
abcde
b
x
y
aaaaaaaaaaaaaaa
a
contest
t
YES
NO
NO
YES
YES

在线编程 IDE

建议全屏模式获得最佳体验