博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
剑指offer 面试29题
阅读量:4597 次
发布时间:2019-06-09

本文共 1191 字,大约阅读时间需要 3 分钟。

面试29题:

题目:顺时针打印矩阵(同LeetCode 螺旋矩阵打印)

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

 

解题方法一:详见剑指offer

 

解题代码:

# -*- coding:utf-8 -*-class Solution:    # matrix类型为二维列表,需要返回列表    def printMatrix(self, matrix):        # write code here        if not matrix or len(matrix)<=0 or len(matrix[0])<=0:            return        start=0        rows=len(matrix)        columns=len(matrix[0])        res=[]        while(columns>start*2 and rows>start*2):            self.printMatrixInCircle(matrix,columns,rows,start,res)            start += 1                    return res        def printMatrixInCircle(self,matrix,columns,rows,start,res):        endX=columns-1-start        endY=rows-1-start                # 从左到右打印一行        for i in range(start,endX+1):            res.append(matrix[start][i])                # 从上到下打印一列        if start

 

解题方法二:Python黑魔法:详细思路见 另一篇文章:

# -*- coding:utf-8 -*-class Solution:    # matrix类型为二维列表,需要返回列表    def printMatrix(self, matrix):        # write code here        return matrix and list(matrix.pop(0))+self.printMatrix(zip(*matrix)[::-1])

 

转载于:https://www.cnblogs.com/yanmk/p/9217230.html

你可能感兴趣的文章
调用底层不能直接访问的类和方法
查看>>
清理缓存的方法 #DF
查看>>
JAVA array,map 转 json 字符串
查看>>
2017-12-27练习
查看>>
NET设计规范(二) 命名规范
查看>>
VMware 9.0.1安装Mac OS X Mountain Lion 10.8.2
查看>>
SSL延迟
查看>>
android新手关于左右滑动的问题,布局把<android.support.v4.view.ViewPager/><ImageView/> 放在上面就不行了。...
查看>>
深入理解DIP、IoC、DI以及IoC容器
查看>>
赋值文件
查看>>
Vue 数组 字典 template v-for 的使用
查看>>
蓝牙模块选择经验谈
查看>>
java中==和equals
查看>>
CCActionPageTurn3D
查看>>
python random
查看>>
esp32-智能语音-cli(调试交互命令)
查看>>
netty与MQ使用心得
查看>>
关于dl dt dd 文字过长换行在移动端显示对齐的探讨总结
查看>>
swoolefy PHP的异步、并行、高性能网络通信引擎内置了Http/WebSocket服务器端/客户端...
查看>>
Python学习笔记
查看>>