题目描述

输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下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)

结束!