观热点:魔方阵口诀_魔方阵c语言

2023-04-22 04:16:10来源:互联网


(相关资料图)

1、代码一:#include #define N 16 //这里可以修改N的值,并且N只能为偶数int main(){int a[N][N]={0},i,j,k,p,m,n;p=1;while(p==1){printf(Enter n(1~%d): ,N-1);/*可以输入小于等于N-1的奇数*/scanf(%d,&n);if((n!=0)&&(nn)){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(%4d,a[i][j]);printf();}}代码二:(相对于代码一条理更清晰,更简单、更易理解)将1~n的平方这几个数构成一个n阶魔方阵。

2、算法:依以下法则,你可以很快的写出奇数阶幻方!当然,这种写法只是其中一个答案,而不是唯一答案。

3、1)将1填入第一行中间;2)将每个数填在前一个数的右上方。

4、3)若该位置超出最上行,则改填在最下行的对应位置;4)若该位置超出最右列,则该填在最左列的对应行位置;5)若某元素填在第一行最右列,下一个数填在该数同列的下一行;6)若某数已填好,但其右上角已填了其他数据,则下一个数填在该数同列的下一行位置。

5、#includevoid main(){int a[15][15]={0},i,j,m,n,temp,M;printf(请输入一个3~15的奇数:);scanf(%d,&M);i=0;j=M/2;a[i][j]=1;for(temp=2;temp<=M*M;temp++){m=i;n=j;i--;j++;if(i<0)i=M-1;if(j>M-1)j=0;if(a[i][j]!=0){i=m+1,j=n;a[i][j]=temp;continue;}a[i][j]=temp;}printf(%d×%d魔方阵:,M,M);for(i=0;i

本文就为大家分享到这里,希望小伙伴们会喜欢。

关键词:

上一篇:
下一篇: