CF2131C.Make it Equal

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

Make it Equal

题目描述

给定两个大小为 nn 的多重集 SSTT,以及一个正整数 kk,你可以对 SS 进行如下操作任意次(包括零次):

  • 选择 SS 中的一个元素 xx,移除 SS 中的一个 xx,然后可以将 x+kx+kxk|x-k| 插入到 SS 中。

请判断是否有可能通过若干次操作使 SS 等于 TT。当且仅当 SSTT 中每个元素出现的次数都相同,两个多重集才相等。

输入格式

每组测试数据包含多组测试用例。第一行为一个整数 tt1t1041 \le t \le 10^4),表示测试用例的组数。每组测试用例描述如下:

第一行包含两个整数 nnkk1n21051 \le n \le 2 \cdot 10^51k1091 \le k \le 10^9),分别表示 SSTT 的大小以及常数 kk

第二行包含 nn 个整数 S1,S2,,SnS_1, S_2, \ldots, S_n0Si1090 \le S_i \le 10^9),表示 SS 中的元素。

第三行包含 nn 个整数 T1,T2,,TnT_1, T_2, \ldots, T_n0Ti1090 \le T_i \le 10^9),表示 TT 中的元素。

保证所有测试用例中 nn 的总和不超过 21052 \cdot 10^5

输出格式

对于每组测试用例,如果可以通过若干次操作使 SS 等于 TT,输出 "YES";否则输出 "NO"。

你可以用任意大小写输出答案(如 "yEs", "yes", "Yes", "YES" 都会被识别为肯定回答)。

说明/提示

在第一个测试用例中,我们可以从 SS 中移除一个 11,并插入 1k=13=2|1-k|=|1-3|=2,此时 SS 就等于 TT

在第二个测试用例中,我们可以从 SS 中移除一个 44,并插入 4+k=4+8=124+k=4+8=12,此时 SS 就等于 TT

在最后一个测试用例中,可以证明无法通过操作使 SS 等于 TT

由 ChatGPT 4.1 翻译

样例

5
1 3
1
2
1 8
4
12
3 5
6 2 9
8 4 11
2 7
2 8
2 9
3 2
0 1 0
1 0 1
YES
YES
YES
NO
NO

在线编程 IDE

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