結果
問題 |
No.401 数字の渦巻き
|
ユーザー |
![]() |
提出日時 | 2018-07-23 21:03:27 |
言語 | Nim (2.2.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 554 bytes |
コンパイル時間 | 3,393 ms |
コンパイル使用メモリ | 65,920 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-07-01 03:16:50 |
合計ジャッジ時間 | 4,419 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 30 |
ソースコード
import strutils, sequtils let N = parseInt readLine stdin var a = newSeqWith(N, newSeqWith(N, 0)) cnt, dir, cls = 0 dirlist = [[0, 1], [1, 0], [0, -1], [-1, 0]] pos: tuple[r, c: int] = (0, -1) while true: var r = pos.r + dirlist[dir][0] c = pos.c + dirlist[dir][1] if r < 0 or N <= r or c < 0 or N <= c or a[r][c] != 0: dir = (dir + 1) mod 4 cls += 1 if cls == 4: break else: cls = 0 cnt += 1 a[r][c] = cnt pos = (r, c) for i, ai in a: write stdout, mapIt(ai, align($it, 3, '0')).join(" "), "\n"