![]() 本人近来遇到一问题,经过我的思索,我解出了这道题,但我中觉得有些遗憾,那就是我编写的程序很繁琐,望提出你宝贵的意见,指导我这个初学者。并愿你我成为不曾相识的朋友!! 例子:打印“魔方阵”。所谓的魔方阵是指住的方阵,它的每一行,每一列和对角线之和均相等。例如,三阶魔方阵为: 8 1 6 3 5 7 4 9 2 要求打印出由一到n^2的自然数构成的魔方阵。 |
![]() 本人近来遇到一问题,经过我的思索,我解出了这道题,但我中觉得有些遗憾,那就是我编写的程序很繁琐,望提出你宝贵的意见,指导我这个初学者。并愿你我成为不曾相识的朋友!! 例子:打印“魔方阵”。所谓的魔方阵是指住的方阵,它的每一行,每一列和对角线之和均相等。例如,三阶魔方阵为: 8 1 6 3 5 7 4 9 2 要求打印出由一到n^2的自然数构成的魔方阵。 |
魔方阵的n=奇数情况是有好算法的。
在第一行中间填1,在它的右上填上2,在2的右上填3,以此类推,右上如果上面没有格子就转到最下面,如果右边没格子了
转到最左边(像一些经典的小游戏一样,向最上面走,你会在最下面出现)。如果该数右上已经有数字,填在该数的下方。一直填,直到填满为止。
这是我以前写的写的不太好请各位高手指点一 二 啊~~~~~
# include<stdio.h> main() { int a[16][16],n,i,j,k; scanf("%d",&n); for(i=1;i<=n;i++) for(j=1;j<=n;j++) a[i][j]=0; j=n/2+1; a[1][j]=1; for(k=2;k<=n*n;k++) { i=i-1;j=j+1; if(i<1&&j>n) { i=i+2;j=j-1;} else { if(i<1) i=n; if(j>n) j=1; } if(a[i][j]==0) a[i][j]=k; else { i=i+2;j=j-1;a[i][j]=k;} } for(i=1;i<=n;i++) { for(j=1;j<=n;j++) printf("%5d",a[i][j]); printf("\n"); } }
多谢各位的帮忙。
我在这里对大家说声谢谢!!!
希望以后还能指教我。