CF1256F Equalizing Two Strings

Description

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 \dots 3] $ and $ t[3 \dots 5] $ , $ s[2 \dots 4] $ and $ t[2 \dots 4] $ , but not $ s[1 \dots 3] $ and $ t[1 \dots 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.

Input Format

The first line of the input contains one integer $ q $ ( $ 1 \le q \le 10^4 $ ) — the number of test cases. Then $ q $ test cases follow. The first line of the test case contains one integer $ n $ ( $ 1 \le n \le 2 \cdot 10^5 $ ) — 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 \cdot 10^5 $ ( $ \sum n \le 2 \cdot 10^5 $ ).

Output Format

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.