1477-神奇的幻方

描述

【问题描述】

幻方是一种很神奇的 NN 矩阵:它由数字 1,2,3, … … , NN 构成,且每行、每列及两条对角线上的数字之和都相同。

当N为奇数时,我们可以通过以下方法构建一个幻方:

首先将 1 写在第一行的中间。

之后,按如下方式从小到大依次填写每个数K(K= 2,3, … , N*N ):

  1. 若 (K−1) 在第一行但不在最后一列,则将K填在最后一行,(K− 1) 所在列的右一列;

  2. 若 (K− 1) 在最后一列但不在第一行,则将K填在第一列,(K− 1) 所在行的上一行;

  3. 若 (K− 1) 在第一行最后一列,则将K填在 (K− 1) 的正下方;

  4. 若 (K− 1) 既不在第一行,也不在最后一列,如果 (K− 1) 的右上方还未填数, 则将K填在(K− 1)的右上方,否则将K填在 (K− 1) 的正下方

现给定N,请按上述方法构造 N*N 的幻方
输入样例:
3
输出样例:
8 1 6
3 5 7
4 9 2
这道题要对着题目给出的4个方法的步骤去写,就可以构成幻方了

#include <stdio.h>
#include <stdlib.h>

int main()
{
   int n,k,x,y,j,i;
   scanf("%d",&n);
   int a[100][100];
   x=0;y=n/2;
   a[x][y]=1;//第一行的中间写1
   for(k=2;k<=n*n;k++)//将2到n*n的数填到二维数组去
   {
       if(x==0&&y!=n-1){
        x=n-1;y=y+1;}
       else if(x!=0&&y==n-1){
        x=x-1;y=0;}
       else if(x==0&&y==n-1){
        x=x+1;y=y;}
       else if(a[x-1][y+1]==0)
           {
            x=x-1;y=y+1;
           }
      else{
            x=x+1;
         }
       a[x][y]=k;
   }
   for(i=0;i<n;i++)
   {
       for(j=0;j<n;j++)
       {
           printf("%d",a[i][j]);
           if(j<n-1)
           printf(" ");
       }
       printf("\n");
   }
   return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值