ABC150F
看到 Shift 先把 {a} 复制一遍。
构造一个新的序列等于 b+(−1)+a+a。
跑一遍魔改的 Z 函数就可以了,即判断当前的 ai⊕bj 是否等于 ai−1⊕bj−1。
最终统计答案的时候如果 zi=n 就输出。
Code:
#include <bits/stdc++.h>
using namespace std;
const int N = 200005;
int n;
int a[N], b[N], s[N*3];
int z[N*3];
void Z() {
int l = 0, r = -1;
int len = n + n + n + 1;
for (int i = 1; i < len; ++i) {
if (i <= r) {
if (i + z[i - l] - 1 < r) z[i] = z[i - l];
else {
z[i] = r - i + 1;
while (i + z[i] < len && (s[i + z[i]] ^ s[z[i]]) == (s[i + z[i] - 1] ^ s[z[i] - 1])) ++z[i];
}
}
else {
z[i] = 1;
while (i + z[i] < len && (s[i + z[i]] ^ s[z[i]]) == (s[i + z[i] - 1] ^ s[z[i] - 1])) ++z[i];
}
if (i + z[i] - 1 > r) l = i, r = i + z[i] - 1;
}
}
int main() {
scanf("%d", &n);
for (int i = 0; i < n; ++i) scanf("%d", &a[i]);
for (int i = 0; i < n; ++i) scanf("%d", &b[i]), s[i] = b[i];
s[n] = -1;
for (int i = 0; i < n; ++i) s[n + i + 1] = s[n + n + i + 1] = a[i];
Z();
for (int i = n + 1; i <= n + n; ++i)
if (z[i] == n) printf("%d %d\n", i - n - 1, a[i - n - 1] ^ b[0]);
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!