幻方计算分析

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
幻方规律:
不管在那个方向1始终在边的中点
上图里面没有0 用0来初始map的值,做标记。
第一个规律:从1开始起点按这个右上斜的规律超出边界到反方向第一个
第二个规律:2-5,右上的时候超出边界反方向第一个填数字
第三个规律:接着右上,到9,10的位置被占用,放在自己的下面
这是一个奇数的幻方,行列相等并且为奇数
写程序思路:
行列需要生气一个二维数组
首先初始化标记为0
找到起点的位置,起点位置为输入的幻方边长/2=4 map[0][4]
总共需要填map[x][y]个数字
定义4个边,行首,行末,列首,列末

  • 行首
    • 当目前的数在行首,且不在列末,那么到行末,列+1
    • 当目前的数在行首,且在行末,行+1
  • 列末
    • 当前数在列末,且不在行首 ,那么行-1,到列首
  • 其他状况
    • 其他数都是右上,如果遇到当前数的位置右上已经不是初始值0那么说明被占用,那么当前行+1
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include<stdlib.h>

int  map[9][9] = {
   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值