結果
問題 | No.2240 WAC |
ユーザー | CoCo_Japan_pan |
提出日時 | 2023-03-10 23:02:58 |
言語 | C++17(gcc12) (gcc 12.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 7 ms / 2,000 ms |
コード長 | 1,073 bytes |
コンパイル時間 | 1,982 ms |
コンパイル使用メモリ | 203,552 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-09-18 05:12:23 |
合計ジャッジ時間 | 3,409 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 43 |
ソースコード
// 提出時にassertはオフ #ifndef DEBUG #ifndef NDEBUG #define NDEBUG #endif #endif #include <bits/stdc++.h> using namespace std; using ll = long long; #define ALL(x) (x).begin(), (x).end() template <class T> using vec = vector<T>; int N, M; string S; int main() { ios_base::sync_with_stdio(false); cin.tie(nullptr); cin >> N >> M >> S; // N個のW,Aのペア、M個のA,Cのペア // つまり添え字の順を見る vec<int> W_index, A_index, C_index; for(int i = 0; i < (int)S.size(); i++) { if(S[i] == 'W') { W_index.push_back(i); } else if(S[i] == 'A') { A_index.push_back(i); } else { C_index.push_back(i); } } bool ansFlag = true; for(int i = 0; i < M; i++) { if(A_index[i] > C_index[i]) { ansFlag = false; break; } } for(int i = 0; i < N; i++) { if(W_index[i] > A_index[M + i]) { ansFlag = false; break; } } cout << (ansFlag ? "Yes" : "No") << "\n"; }