偶然发现xxx中的一道通过率很低的题,本想小试身手,奈何经过了一天的奋战,终于把这道题的通过率又降低了一点(也就测试了50多次吧,惭愧 !惭愧 = 。=!),还好最后终于通过!看似很简单的小题其实还是有点坑的,所以还是记录一下以后做个参考!
原题描述:
输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下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.
思路如下:
1、传统的思路是分析顺时针状态下每个元素的索引值,但是由于索引值变化太大规律及其不明显,因此还是换个思路。想象到由于矩阵在python中是以二维列表的形式出现的,列表中的每个子列表都是矩阵中的每一行,那么我们可以先将矩阵中的第一行元素读取出来加入新的列表中,然后删除这一行,剩下的矩阵我们可以逆时针旋转,然后接着重新读取新矩阵的第一行放入列表,该循环持续到矩阵为空为止;
2、然后就是另一个旋转函数的实现,我们需要重新构造一个与原矩阵行列相反的二维列表,然后按顺序在新的二位列表中加入原矩阵的相关值,具体实现见代码!
话不多说,代码如下!
# -*- coding:utf-8 -*-
"""
Created on Thu Apr 23 16:09:45 2020
@author: ScramJet
"""
class Solution:
def printMatrix(self, matrix): # 首先定义打印矩阵函数
ls = []
while matrix: # 若matrix不为空,就继续执行循环
for k in matrix[0]:
# 遍历矩阵第一行所有元素,并加入列表ls中
ls.append(k)
# 删除矩阵的第一行,为旋转做准备
matrix.remove(matrix[0])