Python JZ29 顺时针打印矩阵(剑指offer)

题目描述

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

Python3 代码

# -*- coding:utf-8 -*-
class Solution:
    # matrix类型为二维列表,需要返回列表
    def printMatrix(self, matrix):
        if matrix:
            res = []
            left, right = 0, len(matrix[0])#获取左右长度,即数组中的每个数组长度
            top, bottom = 0, len(matrix)#获取上下度,即数组中数组个数
            while left < right and top < bottom:
                #当左数值小于右数值,和上数值小于下数值,说明没有打印结束,继续打印
                for i in range(left, right):#从左到右
                    res.append(matrix[top][i])
                for i in range(top + 1, bottom):#从上到下
                    res.append(matrix[i][right - 1])
                    
                if top == bottom - 1:#如果上下是同一行,说明打印结束,直接退出,否则继续执行
                    break    
                lst1 = [x for x in range(left, right - 1)]
                #直接range(1,0,-1),取的是1,不是0,导致结果错误
                lst1.reverse()
                for i in lst1:
                    res.append(matrix[bottom - 1][i])
                    
                if left == right - 1:##如果上下是同一列,说明打印结束,直接退出,否则继续执行
                    break
                lst2 = [x for x in range(top + 1, bottom - 1)]
                lst2.reverse()
                for i in lst2:
                    res.append(matrix[i][left])

                left += 1
                top += 1
                right -= 1
                bottom -= 1
            return res
        else:#空矩阵返回空数组
            return []
            # write code here
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值