n階螺旋矩陣

"""
[
[1,   2,  3, 4,  5], 
[16, 17, 18, 19, 6], 
[15, 24, 25, 20, 7], 
[14, 23, 22, 21, 8], 
[13, 12, 11, 10, 9]
]
"""
def main(n):
    result = [[0] * n for _ in range(n)]
    show_num = 1
    start_line = 0
    row = n - 1
    col = n - 1

    def matrix(start_line, show_num, row, col):
        if row == 0:
            if n % 2 != 0:
                result[n // 2][n // 2] = n * n
        else:
            for i in range(start_line, col):
                result[start_line][i] = show_num
                show_num += 1
            for i in range(start_line, row):
                result[i][row] = show_num
                show_num += 1
            for i in range(row, start_line, -1):
                result[row][i] = show_num
                show_num += 1
            for i in range(col, start_line, -1):
                result[i][start_line] = show_num
                show_num += 1

            return matrix(start_line+1, show_num, row-1, col-1)
    matrix(start_line, show_num, row, col)

    return result


if __name__ == '__main__':
    result = main(4)
    for i in result:
        for x in i:
            print(format(x, '3'), end=' ')
        print()


"""
result:
  1   2   3   4 
 12  13  14   5 
 11  16  15   6 
 10   9   8   7 
"""
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容