题解 | #螺旋矩阵#

螺旋矩阵

http://www.nowcoder.com/practice/7edf70f2d29c4b599693dc3aaeea1d31

Python解法:

#
# 
# @param matrix int整型二维数组 
# @return int整型一维数组
#
class Solution:
    def spiralOrder(self , matrix ):
        # write code here
        result = [] #返回值
        if matrix == []:
            return []
        # 当二维数组是空或任何一个维度是0,直接返回
        m = len(matrix) #行数
        n = len(matrix[0]) # 列数
        if m == 0 or n == 0:
            return result 
        # 二维数组的层数,取决于行和列的较小值
        sizes = (min(m,n)+1)//2
        #大循环,从外向内逐层遍历矩阵
        for i in range(sizes):
            # 从左到右遍历“上边”
            for j in range(i,n-i):
                result.append(matrix[i][j])
            # 从上到下遍历“右边”
            for j in range(i+1,m-i):
                result.append(matrix[j][(n-1)-i])
            # 从右到左遍历“下边”
            for j in range(i+1,n-i):
                #限制条件,因为当遍历内循环时候,四个内循环并不会全部执行
                if (m-1)-i > i: 
                    result.append(matrix[m-1-i][n-1-j])
            # 从下到上遍历“左边”
            for j in range(i+1,m-1-i):
                if i < (n-1)-i:
                    result.append(matrix[m-1-j][i])
        return result
        
全部评论

相关推荐

07-22 11:53
门头沟学院 Java
终于有一个保底的offer了,但感觉是白菜价
北凝a:我想问问,提前批的offer 有问你啥时候到岗吗,如果你还想找其他的怎么办
点赞 评论 收藏
分享
06-02 15:17
门头沟学院 Java
心爱的idea:怎么会呢 应该是打招呼有问题 问就说实习6个月全国可飞随时到岗
点赞 评论 收藏
分享
头顶尖尖的程序员:我也是面了三四次才放平心态的。准备好自我介绍,不一定要背熟,可以记事本写下来读。全程控制语速,所有问题都先思考几秒,不要急着答,不要打断面试官说话。
点赞 评论 收藏
分享
给我发了笔试链接,想着等晚上回去做,结果还没做流程就终止了
伟大的小黄鸭在学习:我猜就是笔试几乎没用,就是用来给用人部门拖时间复筛简历的,可能用人部门筛到你简历觉得不合适就提前挂了
投递小鹏汽车等公司10个岗位
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务