python實現轉圈打印矩陣
更新時間:2019年03月02日 11:04:49 作者:hotpotbo
這篇文章主要為大家詳細介紹了python實現轉圈打印矩陣,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了python實現轉圈打印矩陣的具體代碼,供大家參考,具體內容如下
#! conding:utf-8
__author__ = "hotpot"
__date__ = "2017/10/28 9:40"
def return_edge(matrix, start_col, end_col, start_row, end_row):
if start_row == end_row:
return matrix[start_row][start_col:end_col+1]
elif end_col ==start_col:
res = []
for i in range(start_row,end_row+1):
res.append(matrix[i][end_col])
return res
else:
res2 =[]
res3 =[]
res4=[]
res1 = matrix[start_row][start_col:end_col+1]
for i in range(start_row+1,end_row+1):
res2.append(matrix[i][end_col])
for i in range(end_col-1,start_col-1,-1):
res3.append(matrix[end_row][i])
for i in range(end_row-1,start_row,-1):
res4.append(matrix[i][start_row])
res1.extend(res2)
res1.extend(res3)
res1.extend(res4)
return res1
def spiralOrder( matrix):
if matrix:
row = len(matrix)-1
col = len(matrix[0])-1
start_row = 0
start_col = 0
end_row = row
end_col = col
res =[]
while start_col<=end_col and start_row <= end_row:
res.extend(return_edge(matrix,start_col,end_col , start_row ,end_row))
start_col+=1
end_col-=1
start_row+=1
end_row-=1
return res
else:
return matrix
if __name__ == '__main__':
matrix = [[0 for i in range(3) ]for j in range(3)]
num=1
for m in range(len(matrix)):
for n in range(len(matrix[0])):
matrix[m][n]=num
num+=1
print(spiralOrder( matrix))
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Python實現查找二叉搜索樹第k大的節(jié)點功能示例
這篇文章主要介紹了Python實現查找二叉搜索樹第k大的節(jié)點功能,結合實例形式分析了Python二叉搜索樹的定義、查找、遍歷等相關操作技巧,需要的朋友可以參考下2019-01-01

