CF1451C.String Equality

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

Ashish has two strings aa and bb , each of length nn , and an integer kk . The strings only contain lowercase English letters.

He wants to convert string aa into string bb by performing some (possibly zero) operations on aa .

In one move, he can either

  • choose an index ii ( 1in11 \leq i\leq n-1 ) and swap aia_i and ai+1a_{i+1} , or
  • choose an index ii ( 1ink+11 \leq i \leq n-k+1 ) and if ai,ai+1,,ai+k1a_i, a_{i+1}, \ldots, a_{i+k-1} are all equal to some character cc ( cc \neq 'z'), replace each one with the next character (c+1)(c+1) , that is, 'a' is replaced by 'b', 'b' is replaced by 'c' and so on.

Note that he can perform any number of operations, and the operations can only be performed on string aa .

Help Ashish determine if it is possible to convert string aa into bb after performing some (possibly zero) operations on it.

输入格式

The first line contains a single integer tt ( 1t1051 \leq t \leq 10^5 ) — the number of test cases. The description of each test case is as follows.

The first line of each test case contains two integers nn ( 2n1062 \leq n \leq 10^6 ) and kk ( 1kn1 \leq k \leq n ).

The second line of each test case contains the string aa of length nn consisting of lowercase English letters.

The third line of each test case contains the string bb of length nn consisting of lowercase English letters.

It is guaranteed that the sum of values nn among all test cases does not exceed 10610^6 .

输出格式

For each test case, print "Yes" if Ashish can convert aa into bb after some moves, else print "No".

You may print the letters of the answer in any case (upper or lower).

输入输出样例

  • 输入#1

    4
    3 3
    abc
    bcd
    4 2
    abba
    azza
    2 1
    zz
    aa
    6 2
    aaabba
    ddddcc

    输出#1

    No
    Yes
    No
    Yes

说明/提示

In the first test case it can be shown that it is impossible to convert aa into bb .

In the second test case,

"abba" inc\xrightarrow{\text{inc}} "acca" inc\xrightarrow{\text{inc}} \ldots inc\xrightarrow{\text{inc}} "azza".

Here "swap" denotes an operation of the first type, and "inc" denotes an operation of the second type.

In the fourth test case,

"aaabba" swap\xrightarrow{\text{swap}} "aaabab" swap\xrightarrow{\text{swap}} "aaaabb" inc\xrightarrow{\text{inc}} \ldots inc\xrightarrow{\text{inc}} "ddaabb" inc\xrightarrow{\text{inc}} \ldots inc\xrightarrow{\text{inc}} "ddddbb" inc\xrightarrow{\text{inc}} \ldots inc\xrightarrow{\text{inc}} "ddddcc".

首页