码迷,mamicode.com
首页 > 其他好文 > 详细

输出n阶“魔方阵”

时间:2016-09-30 12:23:28      阅读:106      评论:0      收藏:0      [点我收藏+]

标签:

魔方阵:每一行、每一列和对角线之和均相等。

技术分享

程序如下:

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 int main()
 4 {
 5     //输出魔方阵
 6     int i,j,k,p,n,a[15][15];
 7     p=1;//用于判断输入的数字是否符合条件
 8     while(p==1){
 9         printf("enter n (n=1--15):");
10         scanf("%d",&n);
11         if((n!=0)&& (n<=15) && (n%2!=0))
12             p=0;
13     }
14     //初始化
15     for(i=1;i<=n;i++)
16         for(j=1;j<=n;j++)
17             a[i][j]=0;
18     j=n/2 + 1;
19     a[1][j]=1;
20     for(k=2;k<=n*n;k++){
21         i=i-1;
22         j=j+1;
23         //确立数放置的位置
24         if((i<1) && (j>n)){
25             i=i+2;
26             j=j-1;
27         }
28         else{
29             if(i<1) i=n;
30             if(j>n) j=1;
31         }
32         //置数
33         if(a[i][j]==0){
34             a[i][j]=k;
35         }else{//位置上已有数
36             i=i+2;
37             j=j-1;
38             a[i][j]=k;
39         }
40     }
41     //输出魔方阵
42     for(i=1;i<=n;i++){
43         for(j=1;j<=n;j++)
44             printf("%5d",a[i][j]);
45         printf("\n");
46     }
47     system("pause");
48     return 0;
49 }

 

输出n阶“魔方阵”

标签:

原文地址:http://www.cnblogs.com/crystalmoore/p/5923068.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!