方阵填充自然数 女爷i 2023-03-12 12:29 61阅读 0赞 ### 1004: 方阵填充自然数 ### 时间限制: 1 Sec 内存限制: 125 MB 提交次数: 537 解决: 64 附加描述 > 在一个N\*N的方阵中,填入1,2,……N\*N个数,并要求构成如下的格式: > 例如: > N=5 > 13 14 15 16 1 > 12 23 24 17 2 > 11 22 25 18 3 > 10 21 20 19 4 > 9 8 7 6 5 > > > N=6 > 16 17 18 19 20 1 > 15 30 31 32 21 2 > 14 29 36 33 22 3 > 13 28 35 34 23 4 > 12 27 26 25 24 5 > 11 10 9 8 7 6 > 输入 > > 每个测试文件只包含一组测试数据,每组输入一个N。 > 输出 > > 输出构成的方阵。 > 样例输入 > > 5 > 样例输出 > > 13 14 15 16 1 > 12 23 24 17 2 > 11 22 25 18 3 > 10 21 20 19 4 > 9 8 7 6 5 > 提示 > > N阶方阵范围 1~100 > 使用二维数组保存方阵数据。 > 注意N<=3时候的数据打印间隔。 其原理如图所示一圈圈的填充, ![Center][] #include <iostream> #include <stdlib.h> using namespace std; ///1004 #define DOWN 0 #define LEFT 1 #define UP 2 #define RIGHT 3 #define MAXNUM 100 void FillMatrix(int matrix[MAXNUM][MAXNUM], int size, int num, int offset) { //matrix为总矩阵,size为剩余矩阵的大小,num为要填的第一个数,offset为剩余矩阵在总矩阵中的位置 //递归终止条件 if (size == 0) return; //递归终止条件 if (size == 1) { matrix[offset][offset] = num; return; } //先填充外围 int i; int begin = offset; int end = offset + size -1; for (i = 0;i < size - 1;i++) { matrix[begin + i][end] = num + i + (size - 1) * DOWN; matrix[end ][end- i] = num + i + (size-1) * LEFT; matrix[end - i][begin ] = num + i + (size - 1) * UP; matrix[begin][begin+i] = num + i + (size - 1) * RIGHT; } //再递归填充内核(小了一圈的子矩阵) FillMatrix(matrix, size - 2, num +4*(size-1), offset + 1); } void NxNfill_nNum(int N) { int flag = 0; int i =N, j = N; int nNUM[MAXNUM][MAXNUM] = {0}; //memset(nNUM, 0, sizeof(nNUM)); FillMatrix(nNUM, N, 1, 0); cout.setf(std::ios::left); for (size_t i = 0; i < N; i++) { for (size_t j = 0; j < N; j++) { cout << nNUM[i][j] << " "; }cout << endl; } } int main() { int i = 0; //cout << "please enter a num to start:" << endl; while (cin >> i) { NxNfill_nNum(i); } } ## 测试结果 ## ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQxODY4MTA4_size_16_color_FFFFFF_t_70][] [Center]: /images/20230312/7428d01c99ca44d697b9d8c1fa1275cf.png [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQxODY4MTA4_size_16_color_FFFFFF_t_70]: /images/20230312/fcdf559ea1fa4441814e4bd7215e2596.png
相关 旋转方阵 ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1NpbW9u 旧城等待,/ 2023年07月15日 12:48/ 0 赞/ 127 阅读
相关 方阵填充自然数 1004: 方阵填充自然数 时间限制: 1 Sec 内存限制: 125 MB 提交次数: 537 解决: 64 附加描述 > 在一个N\N的方阵中,填入1,2 女爷i/ 2023年03月12日 12:29/ 0 赞/ 62 阅读
相关 螺旋方阵 所谓“螺旋方阵”,是指对任意给定的NNN,将1到N×NN\\times NN×N的数字从左上角第1个格子开始,按顺时针螺旋方向顺序填入N×NN\\times NN×N的方阵里。 骑猪看日落/ 2022年09月27日 06:18/ 0 赞/ 278 阅读
相关 转方阵 对一个方阵转置,就是把原来的行号变列号,原来的列号变行号 例如,如下的方阵: 1 2 3 4 5 6 7 8 浅浅的花香味﹌/ 2022年08月08日 13:59/ 0 赞/ 177 阅读
相关 转方阵 对一个方阵转置,就是把原来的行号变列号,原来的列号变行号 例如,如下的方阵: 1 2 3 4 5 6 7 8 9 10 11 待我称王封你为后i/ 2022年08月02日 07:20/ 0 赞/ 165 阅读
相关 螺旋方阵 螺旋方阵 Time Limit: 1000MS Memory Limit: 65536KB [Submit][] [ Statistic][S ゝ一纸荒年。/ 2022年07月03日 14:58/ 0 赞/ 217 阅读
相关 螺旋方阵 Problem Description n×n的螺旋方阵当n=5和n=3时分别是如下的形式 ![1295.png][] 请给出一个程序,对于任意的输入n(0 墨蓝/ 2022年06月17日 05:28/ 0 赞/ 230 阅读
相关 螺旋方阵 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 所谓“螺旋方阵”,是指对任意给定的N,将1到N\N的 左手的ㄟ右手/ 2022年05月29日 05:25/ 0 赞/ 248 阅读
相关 将一个自然数拆分为N个自然数 废话不多说,直接上代码 public class A { public static void main(String[] args) { 雨点打透心脏的1/2处/ 2021年11月10日 00:36/ 0 赞/ 419 阅读
相关 方阵相乘 一 代码 package Matrix; / Copyright (C), 2020-2020, XXX有限公司 FileNam 约定不等于承诺〃/ 2021年07月24日 16:15/ 0 赞/ 343 阅读
还没有评论,来说两句吧...