結果
| 問題 | No.401 数字の渦巻き |
| コンテスト | |
| ユーザー |
toshiro_yanagi
|
| 提出日時 | 2018-07-23 21:19:58 |
| 言語 | Nim (2.2.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 505 bytes |
| 記録 | |
| コンパイル時間 | 3,379 ms |
| コンパイル使用メモリ | 65,840 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-07-01 03:17:01 |
| 合計ジャッジ時間 | 4,241 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 30 |
ソースコード
import strutils, sequtils, math
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 cnt < N ^ 2:
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
else:
cnt += 1
a[r][c] = cnt
pos = (r, c)
for i, ai in a:
echo mapIt(ai, align($it, 3, '0')).join(" ")
toshiro_yanagi