鱼C论坛

 找回密码
 立即注册
查看: 1546|回复: 2

[已解决]求大佬帮忙解答一道题目

[复制链接]
发表于 2021-3-19 11:01:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
输出“魔方阵”。所谓魔方阵是指这样的方阵,它的每一行、每一列和对角线之和均相等。例如,三阶魔方阵为
        8   1   6
   3   5   7
   4   9   2
要求输出1~n2 的自然数构成的魔方阵。
(说明:1. 魔方阵的阶数为奇数阶。
    2.  1放在第1行的中间。
         3. 从2 开始直到n*n,各数按此规则存放:每一个数存放的行比前一个数的行数减1,列数加1 。
    4. 如果上一个数的行数为1,则下一个数的行数为n,列数加1。
         5. 如果上一个数的列数为n,则下一个数的列数为1,行数减1。
    6. 如果确定位置上已有数或则上一个数是第1行第n列时,则把下一个数放在上一个数的下面。)
最佳答案
2021-3-19 14:38:08
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. void mf(int n)
  4. {
  5.         int a , b , i , j , k , ** p                                             ;
  6.         if(n > 2 && n % 2) {
  7.                 p = (int **) malloc(sizeof(int *) * n)                           ;
  8.                 for(i = 0 ; i < n ; i ++) p[i] = (int *) malloc(sizeof(int) * n) ;
  9.                 for(i = 0 ; i < n ; i ++) {
  10.                         for(j = 0 ; j < n ; j ++) {
  11.                                 p[i][j] = 0                                      ;
  12.                         }
  13.                 }
  14.                 for(a = i = 0 , b = n / 2 ; i < n * n ; i ++) {
  15.                         p[a][b] = i + 1                                          ;
  16.                         if(! a && b == n - 1) {
  17.                                 a ++                                             ;
  18.                         } else {
  19.                                 if(! a) a = n - 1                                ;
  20.                                 else a --                                        ;
  21.                                 if(b == n - 1) b = 0                             ;
  22.                                 else b ++                                        ;
  23.                                 if(p[a][b]) {
  24.                                         a += 2                                   ;
  25.                                         b --                                     ;
  26.                                 }
  27.                         }
  28.                 }
  29.                 printf("n = %d\n" , n)                                           ;
  30.                 for(i = 0 ; i < n ; i ++) {
  31.                         printf("%5d" , p[i][0])                                  ;
  32.                         for(j = 1 ; j < n ; j ++) printf(" %5d" , p[i][j])       ;
  33.                         printf("\n")                                             ;
  34.                 }
  35.                 printf("\n")                                                     ;
  36.                 for(i = 0 ; i < n ; i ++) free(p[i])                             ;
  37.                 free(p)                                                          ;
  38.         }
  39. }

  40. int main(void)
  41. {
  42.         int i                                                                    ;
  43.         for(i = 3 ; i < 10 ; i += 2) mf(i)                                       ;
  44. }
复制代码

        编译、运行实况
  1. D:\0002.Exercise\C>g++ -o mfx mfx.c

  2. D:\0002.Exercise\C>mfx
  3. n = 3
  4.     8     1     6
  5.     3     5     7
  6.     4     9     2

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

  13. n = 7
  14.    30    39    48     1    10    19    28
  15.    38    47     7     9    18    27    29
  16.    46     6     8    17    26    35    37
  17.     5    14    16    25    34    36    45
  18.    13    15    24    33    42    44     4
  19.    21    23    32    41    43     3    12
  20.    22    31    40    49     2    11    20

  21. n = 9
  22.    47    58    69    80     1    12    23    34    45
  23.    57    68    79     9    11    22    33    44    46
  24.    67    78     8    10    21    32    43    54    56
  25.    77     7    18    20    31    42    53    55    66
  26.     6    17    19    30    41    52    63    65    76
  27.    16    27    29    40    51    62    64    75     5
  28.    26    28    39    50    61    72    74     4    15
  29.    36    38    49    60    71    73     3    14    25
  30.    37    48    59    70    81     2    13    24    35


  31. D:\0002.Exercise\C>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-3-19 14:38:08 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. void mf(int n)
  4. {
  5.         int a , b , i , j , k , ** p                                             ;
  6.         if(n > 2 && n % 2) {
  7.                 p = (int **) malloc(sizeof(int *) * n)                           ;
  8.                 for(i = 0 ; i < n ; i ++) p[i] = (int *) malloc(sizeof(int) * n) ;
  9.                 for(i = 0 ; i < n ; i ++) {
  10.                         for(j = 0 ; j < n ; j ++) {
  11.                                 p[i][j] = 0                                      ;
  12.                         }
  13.                 }
  14.                 for(a = i = 0 , b = n / 2 ; i < n * n ; i ++) {
  15.                         p[a][b] = i + 1                                          ;
  16.                         if(! a && b == n - 1) {
  17.                                 a ++                                             ;
  18.                         } else {
  19.                                 if(! a) a = n - 1                                ;
  20.                                 else a --                                        ;
  21.                                 if(b == n - 1) b = 0                             ;
  22.                                 else b ++                                        ;
  23.                                 if(p[a][b]) {
  24.                                         a += 2                                   ;
  25.                                         b --                                     ;
  26.                                 }
  27.                         }
  28.                 }
  29.                 printf("n = %d\n" , n)                                           ;
  30.                 for(i = 0 ; i < n ; i ++) {
  31.                         printf("%5d" , p[i][0])                                  ;
  32.                         for(j = 1 ; j < n ; j ++) printf(" %5d" , p[i][j])       ;
  33.                         printf("\n")                                             ;
  34.                 }
  35.                 printf("\n")                                                     ;
  36.                 for(i = 0 ; i < n ; i ++) free(p[i])                             ;
  37.                 free(p)                                                          ;
  38.         }
  39. }

  40. int main(void)
  41. {
  42.         int i                                                                    ;
  43.         for(i = 3 ; i < 10 ; i += 2) mf(i)                                       ;
  44. }
复制代码

        编译、运行实况
  1. D:\0002.Exercise\C>g++ -o mfx mfx.c

  2. D:\0002.Exercise\C>mfx
  3. n = 3
  4.     8     1     6
  5.     3     5     7
  6.     4     9     2

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

  13. n = 7
  14.    30    39    48     1    10    19    28
  15.    38    47     7     9    18    27    29
  16.    46     6     8    17    26    35    37
  17.     5    14    16    25    34    36    45
  18.    13    15    24    33    42    44     4
  19.    21    23    32    41    43     3    12
  20.    22    31    40    49     2    11    20

  21. n = 9
  22.    47    58    69    80     1    12    23    34    45
  23.    57    68    79     9    11    22    33    44    46
  24.    67    78     8    10    21    32    43    54    56
  25.    77     7    18    20    31    42    53    55    66
  26.     6    17    19    30    41    52    63    65    76
  27.    16    27    29    40    51    62    64    75     5
  28.    26    28    39    50    61    72    74     4    15
  29.    36    38    49    60    71    73     3    14    25
  30.    37    48    59    70    81     2    13    24    35


  31. D:\0002.Exercise\C>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-3-19 21:12:25 From FishC Mobile | 显示全部楼层
jackz007 发表于 2021-3-19 14:38
编译、运行实况

谢谢谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-30 18:19

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表