魔方 - 暹罗方法

时间:2015-03-05 13:09:47

标签: python magic-square

是否可以在不使用模数的情况下使用Siamese / De La Loubere方法制作魔方?

我想使用它制作奇数n x n魔方。

1 个答案:

答案 0 :(得分:1)

是的,这是可能的。写在Python 3.5上:

def siamese_method(n):

    assert(n % 2 != 0), 'Square side size should be odd!'
    square = [[0 for x in range(n)] for x in range(n)]
    x = 0
    y = int((n + 1) / 2 - 1)
    square[x][y] = 1

    for i in range(2, n * n + 1):
        x_old = x
        y_old = y

        if x == 0:
            x = n - 1
        else:
            x -= 1

        if y == n - 1:
            y = 0
        else:
            y += 1

        while square[x][y] != 0:
            if x == n - 1:
                x = 0
            else:
                x = x_old + 1
            y = y_old

        square[x][y] = i

    for j in square:
        print(j)


siamese_method(3)

我对输出有所了解:

[8, 1, 6]
[3, 5, 7]
[4, 9, 2]