题目描述
输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10.
解答
# coding:utf-8 class Solution: # matrix类型为二维列表,需要返回列表 def printMatrix(self, matrix): # write code here pro = matrix l1 = [] while 1:
# 将矩阵第一行加到l1里面 l1.extend(pro[0])
# 如果矩阵大于一行,就取剩下的行 if len(pro) > 1: pro = pro[1:] else: break
# 90°旋转矩阵
# 双层列表推导式,[[r[i] for r in pro]]里面的i是for i in range(len(pro[0])-1, -1, -1)的值 pro = [[r[i] for r in pro] for i in range(len(pro[0])-1, -1, -1)] return l1 matrix = [[1,2,3],[4,5,6],[7,8,9]] print Solution().printMatrix(matrix)
结束!