CF2200C Specialty String
题目描述
AksLolCoding 正在玩一个关于字符串 $s$ 的游戏,字符串长度为 $n$。初始时,$s$ 只包含小写拉丁字母。
每一回合,AksLolCoding 可以选择一对整数 $(i, j)$,满足:
- $1 \leq i < j \leq n$;
- $s_i = s_j \neq *$;
- 对于所有 $i < k < j$,有 $s_k = *$。
如果不存在这样的 $i,j$,则游戏结束。否则,AksLolCoding 令 $s_i := *$ 且 $s_j := *$。当游戏结束后,只有当 $s$ 的每一个字符都等于 $*$ 时,AksLolCoding 才获胜。请判断是否存在一种操作方式,使得 AksLolCoding 能够获胜。
注意:$*$ 表示 ASCII 字符 42。
输入格式
第一行为一个整数 $t$($1 \leq t \leq 100$),表示测试用例的数量。
每个测试用例的第一行为一个整数 $n$($1 \leq n \leq 5000$),表示字符串的长度。
每个测试用例的第二行为一个仅由小写拉丁字母组成的字符串 $s$。
所有测试用例中 $n$ 的总和不超过 $5000$。
输出格式
对于每个测试用例,输出一行答案。如果 AksLolCoding 能够获胜,输出 "YES"(不带引号);否则,输出 "NO"。
输出不区分大小写。例如,"yEs"、"yes"、"Yes" 和 "YES" 都被认为是正面回答。
说明/提示
在第一个测试用例中,可以证明 AksLolCoding 无法获胜。
在第二个测试用例中,AksLolCoding 可以按以下方式获胜:llmllm $\rightarrow$ llm**m $\rightarrow$ **m**m $\rightarrow$ *****。
在第三个测试用例中,AksLolCoding 可以按以下方式获胜:uwuuwu $\rightarrow$ uw**wu $\rightarrow$ u****u $\rightarrow$ *****。
由 ChatGPT 5 翻译