#D. 洛书

    传统题 1000ms 256MiB

洛书

该比赛已结束,您无法在比赛模式下递交该题目。您可以点击“在题库中打开”以普通模式查看和递交本题。

题目背景

洛书古称龟书,是阴阳五行术数之源。其甲壳上有此图象,结构是戴九履一,左三右七,二四为肩,六八为足,以五居中,五方白圈皆阳数,四隅黑点为阴数。关于洛书的来源,《周易·系辞上》载:“河出图,洛出书,圣人则之。”那么“洛书”究竟是在什么时间,什么地点,由那位圣人,怎样得到的呢,目前还尚无定论,不过聪明的你可以用c++来把这个神秘的洛书来计算出来。

题目描述

洛书其实是一种很神奇的 N×NN\times N 矩阵:它由数字 1,2,3,,N×N1,2,3,\cdots \cdots ,N \times N 构成,且每行、每列及两条对角线上的数字之和都相同。

目前可以计算得知当 NN 为奇数时,我们可以通过以下方法构建一个洛书:

首先将 11 写在第一行的中间。

之后,按如下方式从小到大依次填写每个数 K (K=2,3,,N×N)K \ (K=2,3,\cdots,N \times N) : (注意 : (K)(K)为当前要填的数,那么(K1)(K-1)就是上次已经填好的数)

  1. (K1)(K-1) 在第一行最后一列,或者 (K1)(K-1) 的右上角已经填过数了,则将 KK 填在 (K1)(K-1) 的正下方;
  2. (K1)(K-1) 在第一行但不在最后一列,则将 KK 填在最后一行, (K1)(K-1) 所在列的右一列;
  3. (K1)(K-1) 在最后一列但不在第一行,则将 KK 填在第一列, (K1)(K-1) 所在行的上一行;
  4. (K1)(K-1) 不在上面任何一种情况,则将 KK 填在 (K1)(K-1) 的右上方。

现给定 NN ,请按上述方法构造 N×NN \times N 的洛书。

输入格式

一个正整数 NN,即洛书的大小。

输出格式

NN 行,每行 NN 个整数,即按上述方法构造出的 N×NN \times N 的洛书,相邻两个整数之间用单空格隔开。

样例 #1

样例输入 #1

3

样例输出 #1

8 1 6
3 5 7
4 9 2

样例 #2

样例输入 #2

5

样例输出 #2

17 24 1 8 15
23 5 7 14 16
4 6 13 20 22
10 12 19 21 3
11 18 25 2 9

提示

对于 100%100\% 的数据,对于全部数据, 1N391 \leq N \leq 39NN 为奇数。

字节编程2025年(首届)编程设计比赛-入门组

未参加
状态
已结束
规则
乐多
题目
4
开始于
2025-1-10 12:00
结束于
2025-1-12 4:00
持续时间
4 小时
主持人
参赛人数
9