結果
| 問題 |
No.401 数字の渦巻き
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2018-11-16 20:08:11 |
| 言語 | C (gcc 13.3.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 733 bytes |
| コンパイル時間 | 144 ms |
| コンパイル使用メモリ | 29,952 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-12-24 14:14:07 |
| 合計ジャッジ時間 | 1,159 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 30 |
ソースコード
#include <stdio.h>
int main(void)
{
int N, H = 0, W = 0, ans[30][30] = {}, tmp = 0, i, j;
scanf("%d", &N);
for (i = 0; i < N * N; ++i) {
ans[H][W] = i + 1;
if (tmp % 4 == 0) {
if (W >= N - 1 || ans[H][W + 1] != 0) {
++H;
++tmp;
}
else ++W;
}
else if (tmp % 4 == 1) {
if (H >= N - 1 || ans[H + 1][W] != 0) {
--W;
++tmp;
}
else ++H;
}
else if (tmp % 4 == 2) {
if (W <= 0 || ans[H][W - 1] != 0) {
--H;
++tmp;
}
else --W;
}
else {
if (H <= 0 || ans[H - 1][W] != 0 ) {
++W;
++tmp;
}
else --H;
}
}
for (i = 0; i < N; ++i) {
for (j = 0; j < N; ++j) printf("%03d ", ans[i][j]);
puts("");
}
return 0;
}