結果

問題 No.401 数字の渦巻き
ユーザー kano_town
提出日時 2016-07-22 22:49:38
言語 Java8
(openjdk 1.8.0.222)
結果
AC  
実行時間 210 ms
コード長 1,238 Byte
コンパイル時間 2,943 ms
使用メモリ 23,780 KB
最終ジャッジ日時 2019-11-26 09:53:55

テストケース

テストケース表示
入力 結果 実行時間
使用メモリ
01.txt AC 128 ms
21,808 KB
02.txt AC 129 ms
21,612 KB
03.txt AC 129 ms
21,848 KB
04.txt AC 128 ms
21,644 KB
05.txt AC 123 ms
21,596 KB
06.txt AC 128 ms
21,656 KB
07.txt AC 138 ms
21,732 KB
08.txt AC 132 ms
21,748 KB
09.txt AC 135 ms
21,780 KB
10.txt AC 141 ms
21,820 KB
11.txt AC 146 ms
21,928 KB
12.txt AC 159 ms
22,508 KB
13.txt AC 161 ms
22,536 KB
14.txt AC 173 ms
22,556 KB
15.txt AC 168 ms
22,580 KB
16.txt AC 163 ms
22,648 KB
17.txt AC 172 ms
22,720 KB
18.txt AC 175 ms
22,736 KB
19.txt AC 177 ms
22,808 KB
20.txt AC 175 ms
22,852 KB
21.txt AC 178 ms
22,892 KB
22.txt AC 180 ms
22,952 KB
23.txt AC 189 ms
23,024 KB
24.txt AC 180 ms
23,084 KB
25.txt AC 180 ms
23,140 KB
26.txt AC 189 ms
23,244 KB
27.txt AC 194 ms
23,252 KB
28.txt AC 210 ms
23,376 KB
29.txt AC 199 ms
23,428 KB
30.txt AC 207 ms
23,780 KB
テストケース一括ダウンロード

ソースコード

diff #
import java.util.Arrays;
import java.util.Scanner;

public class Yukicoder401 {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt(), cnt = 1;
        int[] res = new int[n * n];
        Arrays.fill(res, 0);
        int x = 0, y = 0, dx = 1, dy = 0;
        while (cnt <= n * n) {
                res[y * n + x] = cnt++;
                if ((x + dx) < 0 || (x + dx) > n - 1 || (y + dy) < 0 || (y + dy) > n - 1 || res[(y + dy) * n + (x + dx)] != 0) {
                    if (dx == 1) {
                        dx = 0;
                        dy = 1;
                    } else if (dy == 1) {
                        dx = -1;
                        dy = 0;
                    } else if (dx == -1) {
                        dx = 0;
                        dy = -1;
                    } else if (dy == -1) {
                        dx = 1;
                        dy = 0;
                    }
                }
                x += dx;
                y += dy;
        }
        for (y = 0; y < n; y++) {
            for (x = 0; x < n; x++) {
                System.out.printf("%03d ", res[y * n + x]);
            }
            System.out.println("");
        }
    }
}
0