CF1256F.Equalizing Two Strings
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
You are given two strings s and t both of length n and both consisting of lowercase Latin letters.
In one move, you can choose any length len from 1 to n and perform the following operation:
- Choose any contiguous substring of the string s of length len and reverse it;
- at the same time choose any contiguous substring of the string t of length len and reverse it as well.
Note that during one move you reverse exactly one substring of the string s and exactly one substring of the string t .
Also note that borders of substrings you reverse in s and in t can be different, the only restriction is that you reverse the substrings of equal length. For example, if len=3 and n=5 , you can reverse s[1…3] and t[3…5] , s[2…4] and t[2…4] , but not s[1…3] and t[1…2] .
Your task is to say if it is possible to make strings s and t equal after some (possibly, empty) sequence of moves.
You have to answer q independent test cases.
输入格式
The first line of the input contains one integer q ( 1≤q≤104 ) — the number of test cases. Then q test cases follow.
The first line of the test case contains one integer n ( 1≤n≤2⋅105 ) — the length of s and t .
The second line of the test case contains one string s consisting of n lowercase Latin letters.
The third line of the test case contains one string t consisting of n lowercase Latin letters.
It is guaranteed that the sum of n over all test cases does not exceed 2⋅105 ( ∑n≤2⋅105 ).
输出格式
For each test case, print the answer on it — "YES" (without quotes) if it is possible to make strings s and t equal after some (possibly, empty) sequence of moves and "NO" otherwise.
输入输出样例
输入#1
4 4 abcd abdc 5 ababa baaba 4 asdf asdg 4 abcd badc
输出#1
NO YES NO YES