結果
問題 | No.361 門松ゲーム2 |
ユーザー |
|
提出日時 | 2017-07-12 14:41:49 |
言語 | D (dmd 2.109.1) |
結果 |
AC
|
実行時間 | 6 ms / 2,000 ms |
コード長 | 596 bytes |
コンパイル時間 | 916 ms |
コンパイル使用メモリ | 102,012 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-06-12 20:53:25 |
合計ジャッジ時間 | 1,641 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 28 |
ソースコード
import std.algorithm, std.conv, std.range, std.stdio, std.string;void main(){auto rd = readln.split.to!(int[]), l = rd[0], d = rd[1];auto g = new int[](l+1);g[0..6][] = 0;foreach (i; 6..l+1) {auto mex = new bool[](l);foreach (l1; 1..i-1) {auto l2min = max(l1 + 1, i - l1 * 2 - d);auto l2max = (i - l1 + 1) / 2;foreach (l2; l2min..l2max) {auto l3 = i - l1 - l2;mex[g[l1] ^ g[l2] ^ g[l3]] = true;}}auto gi = mex.countUntil!"!a".to!int;g[i] = gi == -1 ? 0 : gi;}writeln(g[l] == 0 ? "matsu" : "kado");}