输出n阶“魔方阵”

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

程序如下:

 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 }

 

转载于:https://www.cnblogs.com/crystalmoore/p/5923068.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值