제출 #124167

#제출 시각아이디문제언어결과실행 시간메모리
124167pedy4000Matching (CEOI11_mat)C++14
100 / 100
450 ms23800 KiB
#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 && R + 1 < m && 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() { scanf("%d %d", &n, &m); for (int i = 0; i < n; i++) { scanf("%d", &Crr[i]); Crr[i]--; Arr[Crr[i]] = i; } processRel(); for (int i = 0; i < m; i++) scanf("%d", &Brr[i]); KMP(); findMatching(); printf("%lu\n", ans.size()); for (int l: ans) printf("%d ", l); return 0; } // S --> 5:45

컴파일 시 표준 에러 (stderr) 메시지

mat.cpp: In function 'int main()':
mat.cpp:85:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d %d", &n, &m);
  ~~~~~^~~~~~~~~~~~~~~~~
mat.cpp:87:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d", &Crr[i]);
   ~~~~~^~~~~~~~~~~~~~~
mat.cpp:96:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d", &Brr[i]);
   ~~~~~^~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...