結果
問題 |
No.351 市松スライドパズル
|
ユーザー |
|
提出日時 | 2019-01-19 17:52:10 |
言語 | Nim (2.2.0) |
結果 |
AC
|
実行時間 | 41 ms / 2,000 ms |
コード長 | 900 bytes |
コンパイル時間 | 2,175 ms |
コンパイル使用メモリ | 61,296 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-01 10:22:46 |
合計ジャッジ時間 | 3,690 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 17 |
ソースコード
proc getchar_unlocked():char {. importc:"getchar_unlocked",header: "<stdio.h>" .} proc scan(): int32 = while true: var k = getchar_unlocked() if k < '0': break result = 10 * result + k.ord.int32 - '0'.ord.int32 let h = scan() let w = scan() let n = scan() var ops: array[1000010,int16] for i in 0..<n: let isC = getchar_unlocked() == 'C' discard getchar_unlocked() var k = cast[int16](0) while true: var c = getchar_unlocked() if c < '0': break k = cast[int16](10) * k + cast[int16](c) - cast[int16]('0') if isC : ops[i] = k+1 else: ops[i] = -k-1 var x = 0 var y = 0 for i in 1..n: var op = ops[n-i] let isC = op > 0 if isC: op -= 1 if x != op: continue if y == 0: y = h - 1 else: y -= 1 else: op = -op - 1 if y != op: continue if x == 0: x = w - 1 else: x -= 1 if (x mod 2) == (y mod 2) : echo "white" else:echo "black"