# # 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 # # # @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