C编程玩转魔方游戏

      Hello,大家好。今天和大家分享一个趣味数学的魔方问题。相信之前,你们都玩过《某者》或寒暑假作业后面的趣味填数游戏。给你一个某种大小的矩阵(一般都是奇数3x3, 5x5, 7x7...), 每个单元取自然数,简单点的会先给你填好几个数字,要求你填出剩下的空格,使每行、每列,以及两条主对角线的和都相等。

6217760-f1d88b8e9b9d1fe2.jpg
空格最大数字为25.最小为1.填上剩余空格数字,使横纵斜之和为65

      小伙伴们,如果做不出来,看我如何让C语言帮我们快速获得结果。

       在开始编程之前,首先了解一下破解此类数独魔方游戏的"葵花宝典"☞Coxeter规则:(PS大家可以结合上图,边看边填!)

      开始时,在 魔方第一行的中间一格放 1。然后重复以下步骤:移 动到左上一格,把当前的数加 1放 在这个位置。如果移动时超 出魔方范围,则 想象与当前状态完全相同的另一个魔方,对齐紧靠在超 出的那条边界线上,因 而可以继续。如果移动到的格子 已经放置过数字,则 从这个格子的位置向正下方移动一格。直到把所有格子都放满数字为止!大家做出来了吗?

6217760-c8cce6510037f78c.jpg
你填对了吗?

好,废话不多说。直接看Code

#include

#define MAX_SIZE 15 /* maximum size of square */

void main (void)

{  /*construct a magic square, iterativety */

int square[MAX_SIZE][MAX_SIZE] ;

int i, j, row, col; /* indexes * /

int count; /* counter * /

int size; /* square size * /

printf ( "Enter-the-size-of-the-square: -" ) ;

scanf ("%d" , &size) ;

/* check for input errors */

if (size<1 | | size>MAX_SIZE) {

fprintf (stderr ,"size  out of range\n") ;

exit (EXIT_FAILURE) ;

}

if (! (size%2)) {

  fprintf (stderr, "Error!-Size-is-even\n" );

  exit (EXIT_FAILURE) ;

}

for (i=0; i<size;i++)

  for (j=0; j<size; j++) square[i][j] = 0 ;

square[0][(size-1) /2]=1;

/* middle of first row * /

i = 0;    j = (size-1) /2;

/* i and j are curent position * /

for (count=2 ; count<=size*size; count++ ) {

row = (i-1<0) ? (size-1) : (i-1) ; /* up * /

col = (j -1<0) ? (size-1) : (j -1) ; /* lef t */

if (square [row] [col] ) i = (++i) % size;

/* down */

else { i = row; j = (j-1<0) ? (size-1) : --j; } /*square r,s unoccupied * /

square[i][j]  = count ;

}

/* output the magic square */

printf ( "Magic-square-of-size-%d:\n\n" , size) ;

for (i=0; i<size; i++) {

   for (j=0; j<size;j++)

   printf("%5d   ",square[i][j]);

printf("\n");

}

printf("\n\n");

}
机器测试通过。无图无真相!

6217760-80fdfaa44e4d226a.jpg
Part one

6217760-81157a38999a9d62.jpg
Part two
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Leon_George

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值