Algorithm Gossip: 奇数魔方阵

说明:
将1到n(为奇数)的数字排列在nxn的方阵上,且各行、各列与各对角线的和必须相同

解法
1在一行正中央,依次斜填切莫忘;
上出框界往下填,右出框界往左填;
重复下移一格填,出角重复一个样。

#include <stdio.h> 
#define N 7 
int main(void) { 
   int i, j, key; 
   int square[N+1][N+1] = {0}; 
   i = 0; 
   j = (N+1) / 2; 
   for(key = 1; key <= N*N; key++) { 
      if((key % N) == 1)  //处理重复情况
         i++; 
      else { 
           i--; 
           j++; 
      } 
      if(i == 0)          //处理上出边界情况
          i = N; 
      if(j > N)           //处理右出边界情况
          j = 1; 
      square[i][j] = key; 
   } 
   for(i = 1; i <= N; i++) {  //输出方阵
      for(j = 1; j <= N; j++) 
          printf("%2d ", square[i][j]); 
      printf("\n");
   } 
return 0; 
} 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值