#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
#
# @param matrix int整型二维数组
# @return int整型一维数组
#
class Solution:
def spiralOrder(self , matrix: List[List[int]]) -> List[int]:
# write code here
if not matrix:return []
res=[]
#设立四边界
left,right,up,down=0,len(matrix[0])-1,0,len(matrix)-1
while True:
#按顺序进行遍历,每次遍历完成后,对边界进行更新
#例如:
#从左至右,遍历上边界
for i in range(left,right+1):
res.append(matrix[up][i])
#遍历完上边界,上边界向中间靠拢
up+=1
#如果上边界大于下边界立刻终止循环
if up>down:break
#后面每条边界逻辑同上
for i in range(up,down+1):
res.append(matrix[i][right])
right-=1
if right<left:break
for i in range(right,left-1,-1):
res.append(matrix[down][i])
down-=1
if down<up:break
for i in range(down,up-1,-1):
res.append(matrix[i][left])
left+=1
if left>right:break
return res