Python实现奇数阶幻方(不用numpy)

幻方(Magic Square),又称纵横图,即在一个n x n的方阵中,放入1~n2的数字,使之各行、各列和两条对角线上的数字之和正好都相等。
一个最基本的三阶幻方大概就是这个样子(当然,他们的镜像也都是可以的)。
在这里插入图片描述
对于幻方的构造,有一个经典的方法:

1、数字 1 放在首行最中间的格子中;
2、向右上角斜行,依次填入数字;
3、如果右上方出了上边界,就以出框后的虚拟方格位置为基准,将数字竖直降落至底行对应的格子中;
4、同样,如果右上方出了右边界,就以出框后的虚拟方格位置为基准,将数字平移至最左列对应的格子中;
5、如果数字右上的格子已被其它数字占领,就将 填写在下面的格子中;
如果朝右上角出界,和上面重复的情况做同样处理。
就像这样:
在这里插入图片描述

这种方法是由法国人罗伯(de la loubere)总结出来的,所以该方法也叫罗伯法。

接下来用Python实现:

def fun(n):
    # 构造一个二维数组并将 1 填入
    lists=[[0 for i in range(n)]for i in range(n)]
    lists[0][n//2]=1
    # 初始坐标
    x=0
    y=n//2
    for i in range(2,n**2+1):
        # 最上边
        if x-1<0:
            x=n-1
        else:
            x-=1
        # 最右边
        if y+1==n:
            y=0
        else:
            y+=1
        while 1:
            if lists[x][y]==0:
                lists[x][y]=i
                break
            else:
                # 获取上一个数字的坐标
                for a in range(n):
                    for b in range(n):
                        if lists[a][b]==i-1:
                            before_x=a
                            before_y=b
                # 使当前数字的坐标变成上一个数字下面的坐标
                x=before_x+1
                y=before_y
                # 当前数字在最下面
                if x>n-1:
                    x=0
    for i in lists:
        print(i)
fun(5)

运行结果:
在这里插入图片描述

  • 10
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值