結果
問題 |
No.769 UNOシミュレータ
|
ユーザー |
|
提出日時 | 2018-12-16 22:52:30 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 960 bytes |
コンパイル時間 | 838 ms |
コンパイル使用メモリ | 74,852 KB |
最終ジャッジ日時 | 2025-01-06 19:37:14 |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 11 WA * 12 |
ソースコード
#include <iostream> #include <vector> int main() { int N, M; std::cin >> N >> M; std::vector<std::string> l(M); for (int i = 0; i < M; i++) { std::cin >> l[i]; } std::vector<int> pay(N, 0); int p = 0, t = 0, rot = 1; for (; t < M;) { if (l[t] == "number") { pay[p]++, t++; } else if (l[t] == "drawtwo") { int cost = 0; for (; l[t] == "drawtwo"; t++, cost += 2, (p += rot) %= N) { pay[p]++; } pay[p] -= cost; } else if (l[t] == "drawfour") { int cost = 0; for (; l[t] == "drawfour"; t++, cost += 4, (p += rot) %= N) { pay[p]++; } pay[p] -= cost; } else if (l[t] == "skip") { pay[p]++, t++, (p += rot) %= N; } else { pay[p]++, t++, rot = (N - rot); } (p += rot) %= N; } (p += N - rot) %= N; std::cout << p + 1 << " " << pay[p] << std::endl; return 0; }