Python是一種被廣泛應用的計算語言,它有著強大的功能和易于上手的特點。對于數組這樣的數據類型,Python也提供了許多優秀的解決方案。本文將介紹Python中的一種蛇形數組實現算法。
def snake_array(n): """ 生成n*n的蛇形數組 """ # 初始化數組 result = [[0] * n for i in range(n)] # 設定行和列的起始位置 row_begin = col_begin = 0 row_end = col_end = n - 1 count = 1 # 生成蛇形數組 while row_begin<= row_end and col_begin<= col_end: # 從左到右 for i in range(col_begin, col_end + 1): result[row_begin][i] = count count += 1 row_begin += 1 # 從上到下 for i in range(row_begin, row_end + 1): result[i][col_end] = count count += 1 col_end -= 1 # 從右到左 for i in range(col_end, col_begin - 1, -1): result[row_end][i] = count count += 1 row_end -= 1 # 從下到上 for i in range(row_end, row_begin - 1, -1): result[i][col_begin] = count count += 1 col_begin += 1 return result
上述代碼中,我們定義了一個函數snake_array(n),它接受一個整數n作為參數,返回一個n * n的蛇形數組。具體實現方法為,先定義一個n * n的二維列表,初始值均為0。接下來,根據蛇形數組的特點,沿著四個方向不斷地填入數字,最終生成蛇形數組。
使用該函數得出的蛇形數組示例:
>>>snake_array(5) [[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]]
通過上面的例子可以看到,我們成功地生成了一個5 * 5的蛇形數組。該算法簡單易懂,適用于生成各種規模的蛇形數組。
上一篇mysql創建表面試題
下一篇python 行值篩選