結果
問題 |
No.1770 N言っちゃダメゲーム (6)
|
ユーザー |
![]() |
提出日時 | 2019-08-22 22:41:29 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,193 bytes |
コンパイル時間 | 1,419 ms |
コンパイル使用メモリ | 168,188 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-07-03 20:55:00 |
合計ジャッジ時間 | 8,314 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | WA * 3 |
other | WA * 44 |
ソースコード
#include <bits/stdc++.h> using namespace std; bool iswin(int n, int k) { if (n == 1) return false; if (k == 1) return true; int p = k + 1, h = 0; while (p % 2 == 0) { p /= 2; h++; } if (h % 2 == 0) return (n - 1) % (k + 1) != 0; if (h == 1) { if (n % 8 == 1) { int r = (n - 1) % (2 * (k + 2) + (k + 1)); if (r == 0 || r == k + 2 || r == 2 * (k + 2)) { return false; } else { return true; } } else { int r = (n - 1) % ((k + 2) + (k + 1)); if (r == 0 || r == k + 2) { return false; } else { return true; } } } else { int r = (n - 1) % ((k + 2) + 2 * (k + 1)); if (r == 0 || r == k + 2 || r == (k + 2) + (k + 1)) { return false; } else { return true; } } } int main() { int p; cin >> p; for (int i = 0; i < p; i++) { int n, k; cin >> n >> k; if (iswin(n, k)) { cout << "Win" << endl; } else { cout << "Lose" << endl; } } }