Условие
Вывести квадрат, состоящий из $N \times N$ клеток, заполненных числами от $1$ до $N^{2}$ по спирали.
Входные данные
В первой строке находится единственное число $N (2 \leq N \leq 100)$.
Выходные данные
Выводится $N$ строк по $N$ чисел, разделённых пробелами. Не допускается начинать спираль в ином, кроме верхнего левого, углу, закручивать спираль против часовой стрелки или изнутри наружу.
Тесты
№ | Входные данные | Выходные данные |
1 | 3 | 1 2 3 8 9 4 7 6 5 |
2 | 4 | 1 2 3 4 12 13 14 5 11 16 15 6 10 9 8 7 |
3 | 5 | 1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9 |
4 | 10 | 1 2 3 4 5 6 7 8 9 10 36 37 38 39 40 41 42 43 44 11 35 64 65 66 67 68 69 70 45 12 34 63 84 85 86 87 88 71 46 13 33 62 83 96 97 98 89 72 47 14 32 61 82 95 100 99 90 73 48 15 31 60 81 94 93 92 91 74 49 16 30 59 80 79 78 77 76 75 50 17 29 58 57 56 55 54 53 52 51 18 28 27 26 25 24 23 22 21 20 19 |
Программный код
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
class Main{ public static void main (String[] args) throws java.lang.Exception { java.util.Scanner in = new java.util.Scanner(System.in); int n, m = 1; n = in.nextInt(); int a[][]; a = new int [n][n]; if(n % 2 != 0){ a[(n / 2)][(n / 2)] = (n * n); // если N - нечетное то находим центр матрицы и заполняем его числом N * N } for(int i = 0; i < (n / 2); i++){ for(int j = i; j < (n - i); j++){ // (n - i) - чтоб с каждым разом сторона становилась меньше a[i][j] = m; m++; } for(int j = 1; j = i; j--){ // (n - 2) - i - отнимаем 1 чтоб не выходило за рамки массива и еще одну 1 a[(n - i) - 1][(j)] = m; // потому-что предыдущий эл. уже заполнен. m++; } for(int j = ((n - i) - 2); j > i; j--){ a[j][i] = m; m++; } } for(int i = 0; i < n; i++){ for(int j = 0; j < n - 1; j++){ System.out.print(a[i][j] + " "); } System.out.println(a[i][n - 1]); } } } |
Решение
Для того чтобы решить эту задачу нам нужно определить способ заполнения. Первым делом, если $N$ — нечетное, то находим центр матрицы и заполняем его числом $N \times N $ a[(n / 2)][(n / 2)] = (n * n);. В условии написано, что “Не допускается начинать спираль в ином, кроме верхнего левого углу, закручивать спираль против часовой стрелки или изнутри наружу.”, то есть начинать мы будем с верхнего левого угла. Для этого мы сделаем цикл for(int i = 0; i < (n / 2); i++); , в котором сделаем 4 такта. Каждый такт заполняет определенную часть матрицы:
-
- 1 такт – заполняет верхнюю грань слева направо;
- 2 такт – заполняет правую грань сверху вниз;
- 3 такт – заполняет нижнюю грань справа налево;
- 4 такт – заполняет левую грань снизу вверх, как показано на рисунке ниже.
Выводим все как обычную матрицу, но с одним условием, после последнего элемента не должно стоять пробела, поэтому я вывел последний элемент отдельно и после него осуществил переход на новую строку.
Ссылки:
Задача на e-olymp
Код на OnlineGDB
Код на Ideone
Засчитанное решение на e-olymp