結果
| 問題 |
No.401 数字の渦巻き
|
| コンテスト | |
| ユーザー |
toshiro_yanagi
|
| 提出日時 | 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"
toshiro_yanagi