python画正方形旋转_Python 旋转打印各种矩形的方法

打印旋转矩阵应该是很经典的算法问题了。

题目描述如下:

给定一个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

result.append(matrix[i][j])

j+=1

while i

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=0

up_lie=0

down_hang=3

down_lie=3

if down_hang>down_lie:

flag=down_lie

else:

flag=down_hang

while 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/2

print(re_mat)

总结:python对于代码的对齐方式要求的比较严格,对齐方式直接决定了函数或者判断条件的作用域,要重视啊。

以上这篇Python 旋转打印各种矩形的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

时间: 2019-07-08

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值