#ATarc145e. [ARC145E] Adjacent XOR

[ARC145E] Adjacent XOR

题目描述

给定两个长度为 NN 的非负整数序列 A=(A1,A2,,AN)A=(A_1,A_2,\ldots,A_N)B=(B1,B2,,BN)B=(B_1,B_2,\ldots,B_N)

请判断是否可以通过不超过 7000070000 次如下操作,将序列 AA 变为序列 BB。如果可以,请给出一种实际的操作方案。

  • 选择一个整数 K (1KN)K\ (1\leq K \leq N)。对于所有 i (2iK)i\ (2\leq i \leq K),将 AiA_i 的值替换为 Ai1AiA_{i-1} \oplus A_i。该替换对所有满足条件的 ii 同时进行。

这里,\oplus 表示按位异或(XOR)运算。

按位异或(XOR)运算定义如下:对于非负整数 A,BA,BABA\oplus B 的二进制表示中,每一位的值等于 A,BA,B 在该位上的值仅有一个为 11 时为 11,否则为 00

例如,35=63\oplus 5 = 6(二进制为:011101=110011\oplus 101 = 110)。

输入格式

输入通过标准输入给出,格式如下:

NN A1A_1 A2A_2 \ldots ANA_N B1B_1 B2B_2 \ldots BNB_N

输出格式

如果无法在 7000070000 次操作内将 AA 变为 BB,输出 No

如果可以,设操作次数为 MM,第 ii 次操作选择的整数为 KiK_i,则输出如下格式:

Yes MM K1K_1 K2K_2 \ldots KMK_M

如果存在多种满足条件的方案,输出任意一种均可。

样例 1

输入

3
1 2 0
1 2 3

输出

Yes
2
2 3

样例 2

输入

2
10 100
1 0

输出

No

样例 3

输入

2
1152921504606846975 0
1152921504606846975 0

输出

Yes
0

说明/提示

限制条件

  • 2N10002 \leq N \leq 1000
  • 0Ai,Bi<2600 \leq A_i, B_i < 2^{60}
  • 所有输入均为整数

样例解释 1

在该输出样例中,序列 AA 经过如下变化:

  • 初始状态:A=(1,2,0)A=(1,\,2,\,0)
  • 11 次操作后:A=(1,3,0)A=(1,\,3,\,0)
  • 22 次操作后:A=(1,2,3)A=(1,\,2,\,3)

经过 22 次操作后,AABB 完全一致,因此该输出满足条件。

由 ChatGPT 4.1 翻译