#include <algorithm>
#include <cstring>
#include <iostream>
#include <vector>
using namespace std;
const int MAX_N = 1e6 + 6;
int n, m;
int Arr[MAX_N];
int Brr[MAX_N];
int Crr[MAX_N];
int F[MAX_N];
int sm[MAX_N];
int bg[MAX_N];
vector <int> ans;
bool can (int *list, int l, int r) {
int ind = r - l;
if (list[r] < list[l + sm[ind]])
return false;
if (list[l + bg[ind]] < list[r])
return false;
return true;
}
void KMP() {
F[1] = 0;
F[2] = 1;
int ind = 1;
for (int i = 3; i <= n; i++) {
while (ind && !can(Arr, i - ind - 1 , i - 1))
ind = F[ind];
ind++;
F[i] = ind;
}
}
void processRel() {
sm[Crr[0]] = Crr[0];
for (int i = 1; i < n; i++) {
sm[Crr[i]] = Crr[i];
int ind = Crr[i - 1];
while (sm[ind] != ind && Crr[i] < ind)
ind = sm[ind];
if (ind <= Crr[i])
sm[Crr[i]] = ind;
}
bg[Crr[n - 1]] = Crr[n - 1];
for (int i = n - 2; ~i; i--) {
bg[Crr[i]] = Crr[i];
int ind = Crr[i + 1];
while (bg[ind] != ind && Crr[i] < ind)
ind = bg[ind];
if (ind <= Crr[i])
bg[Crr[i]] = ind;
}
}
void findMatching() {
int L = 0, R = 0;
while (L < m) {
while (R + 1 < L + n && can(Brr, L, R + 1))
R++;
if (R - L == n - 1)
ans.push_back(L + 1);
if (L == R)
L++, R++;
else
L += R - L + 1 - F[R - L + 1];
}
}
int main() {
ios::sync_with_stdio(false), cin.tie(0);
cin >> n >> m;
for (int i = 0; i < n; i++) {
cin >> Crr[i];
Crr[i]--;
Arr[Crr[i]] = i;
}
processRel();
for (int i = 0; i < m; i++)
cin >> Brr[i];
KMP();
findMatching();
cout << ans.size() << "\n";
for (int l: ans)
cout << l << (ans.back() == l? "\n": " ");
return 0;
}
// S --> 5:45
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
2 ms |
376 KB |
Output is correct |
2 |
Correct |
2 ms |
376 KB |
Output is correct |
3 |
Correct |
2 ms |
376 KB |
Output is correct |
4 |
Incorrect |
2 ms |
376 KB |
Output isn't correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
2 ms |
380 KB |
Output is correct |
2 |
Correct |
2 ms |
376 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
5 ms |
632 KB |
Output is correct |
2 |
Correct |
5 ms |
760 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
5 ms |
760 KB |
Output is correct |
2 |
Correct |
5 ms |
632 KB |
Output is correct |
3 |
Correct |
2 ms |
504 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
28 ms |
3292 KB |
Output is correct |
2 |
Correct |
26 ms |
2472 KB |
Output is correct |
3 |
Correct |
41 ms |
4320 KB |
Output is correct |
4 |
Correct |
41 ms |
4284 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
34 ms |
4228 KB |
Output is correct |
2 |
Correct |
32 ms |
3252 KB |
Output is correct |
3 |
Correct |
35 ms |
3940 KB |
Output is correct |
4 |
Correct |
42 ms |
4692 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
34 ms |
4216 KB |
Output is correct |
2 |
Correct |
31 ms |
3576 KB |
Output is correct |
3 |
Correct |
33 ms |
3576 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
175 ms |
19580 KB |
Output is correct |
2 |
Correct |
381 ms |
40220 KB |
Output is correct |
3 |
Correct |
119 ms |
11668 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
176 ms |
20404 KB |
Output is correct |
2 |
Incorrect |
126 ms |
11100 KB |
Output isn't correct |
3 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
140 ms |
14324 KB |
Output is correct |
2 |
Correct |
217 ms |
22020 KB |
Output is correct |
3 |
Correct |
163 ms |
15672 KB |
Output is correct |
4 |
Correct |
275 ms |
38284 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
154 ms |
15676 KB |
Output is correct |
2 |
Correct |
157 ms |
15940 KB |
Output is correct |
3 |
Correct |
75 ms |
8412 KB |
Output is correct |
4 |
Correct |
275 ms |
36860 KB |
Output is correct |