結果
問題 |
No.1695 Mirror Mirror
|
ユーザー |
![]() |
提出日時 | 2021-08-10 05:21:33 |
言語 | C++17(clang) (17.0.6 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,453 bytes |
コンパイル時間 | 3,729 ms |
コンパイル使用メモリ | 180,224 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-07-19 09:44:58 |
合計ジャッジ時間 | 7,202 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 WA * 1 |
other | AC * 21 WA * 40 |
ソースコード
#include <bits/stdc++.h> #include <atcoder/all> using namespace std; using namespace atcoder; typedef long long ll; int main(){ int N, M; cin >> N >> M; string S, T; cin >> S; cin >> T; if(M%2==1){cout << -1 << endl;return 0;} for(int i=0;i<M/2;i++){ if(T[i]!=T[M-1-i]){ cout << -1 << endl; return 0; } } M/=2; T = T.substr(0,M); int INF = 1<<30; vector<int>dp(M,INF); for(int i=0;i<N;i++){ if(i>=M||S[i]!=T[i])break; dp[i] = 1; } for(int i=0;i<N;i++){ if(i>=M||S[N-1-i]!=T[i])break; dp[i] = 1; } //貪欲に伸ばす int itr = -1; for(int i=M-1;i>=0;i--){ if(dp[i] == 1){ itr = i; break; } } if(itr == -1){ cout << -1 << endl; return 0; } //cout << itr << endl; while (true) { int c = dp[itr]; int nitr = -1; for(int i=0;itr+i+1<M;i++){ if(S[itr-i] == S[itr+1 + i]){ dp[itr + 1 + i] = c + 1; nitr = itr + 1 + i; } else{ break; } } if(nitr==-1){ cout << -1 << endl; return 0; } itr = nitr; //cout << "nitr = " << nitr << endl; if(itr == M - 1){ break; } } cout << dp[M-1] << endl; return 0; }