【Python】旋转打印各种矩形
来源:互联网 发布:中电科大数据研究院 编辑:程序博客网 时间:2024/05/22 12:42
打印旋转矩阵应该是很经典的算法问题了。题目描述如下:
给定一个m * n要素的矩阵。按照螺旋顺序,返回该矩阵的所有要素。
思路:1,先定义矩阵的左上和右下的坐标,然后通过两个坐标来打印这一圈矩阵;
2,将左上的坐标下右下移动,右下的坐标向左上移动,来缩小打印圈,进行下一圈矩阵的打印;
3,一直缩小打印直到结束。
代码:
def print_circle(matrix,up_hang,up_lie,down_hang,down_lie): result=[] if up_lie==down_hang and down_hang==down_lie: # 若只有一个元素 result.append(matrix[up_hang][up_lie]) elif up_lie==down_hang or up_lie==down_lie: #若只有一行或一列元素 if up_lie==down_hang: while up_lie <= down_lie: result.append(matrix[up_hang][up_lie]) up_lie+=1 elif up_lie==down_lie: while up_hang <=down_hang: result.append(matrix[up_hang][up_lie]) up_hang+=1# return result #注意对齐方式,其决定了作用的区间范围,很关键 return result i=up_hang j=up_lie while j<down_lie: result.append(matrix[i][j]) j+=1 while i<down_hang: result.append(matrix[i][j]) i+=1 while j>up_lie: result.append(matrix[i][j]) j-=1 while i>up_hang: result.append(matrix[i][j]) i-=1 return result#matrix=[[1,2,3],[4,5,6],[7,8,9],[10,11,12],[13,14,15],[16,17,18]]#matrix=[[1,2,3,4,5],[6,7,8,9,10],[11,12,13,14,15],[16,17,18,19,20],[21,22,23,24,25]]matrix=[[1,2,3,4],[5,6,7,8],[9,10,11,12],[13,14,15,16]]#matrix=[[1,2,3],[4,5,6],[7,8,9]]#matrix=[[1,2],[3,4]]re_mat=[]up_hang=0up_lie=0down_hang=3down_lie=3if down_hang>down_lie: flag=down_lieelse: flag=down_hangwhile flag!=0: #flag决定了一个矩阵需要打印多少圈 temp=print_circle(matrix,up_hang,up_lie,down_hang,down_lie) re_mat.extend(temp) up_hang+=1 up_lie+=1 down_hang-=1 down_lie-=1 flag=flag/2print(re_mat)总结:python对于代码的对齐方式要求的比较严格,对齐方式直接决定了函数或者判断条件的作用域,要重视啊。
0 0
- 【Python】旋转打印各种矩形
- python 打印菱形、三角形、矩形
- opencv-Python旋转矩形框裁减
- python+opencv图片旋转矩形分割
- 矩形旋转
- 打印矩形
- 旋转打印。
- 旋转打印
- openglesForC++矩形旋转
- 旋转矩形框
- 080426打印矩形
- 矩形打印和碰撞
- Java 矩形打印方法
- "黑马程序员" 打印矩形
- 三角形与矩形打印
- 编程技巧-打印矩形
- 顺时针打印矩形列表
- 打印大写字母矩形
- 蓝桥杯-十六进制转十进制
- 更新页脚合计值
- android画图并实现撤销功能
- ubuntu 14.04 开发环境配置
- MySql-5.7.17 -win32的安装配置
- 【Python】旋转打印各种矩形
- Android中的事件传递机制学习
- 浅谈MySQL连接查询与外键
- linux(ubuntu)编译busybox遇到的问题处理办法
- 机器学习
- [大学课程_经管文史类]财务_会计_审计_视频教程目录
- MarkdownSimpleWorld笔记
- 通过源安装的tomcat7开启与关闭
- 机器学习实战笔记(1)——k-近邻算法