顺时针打印矩阵元素(python实现)

本文介绍了一种简单易懂的矩阵遍历算法,该算法通过从矩阵的最外层向内层进行遍历来实现。文章提供了详细的算法实现过程,并附带Python代码示例。

我觉得我的算法比较简单易懂,比网上的那些简单些。至于时间复杂度就没有比较了。

算法思想:从最外层向内层遍历矩阵

# my algorithm
import math def print_matrix(matrix): rec = [] # 存储遍历元素 rows = len(matrix) cols = len(matrix[0]) if rows < cols: k = math.ceil(rows/2) else: k = math.ceil(cols/2) for n in range(k): # 总的循环次数 # 最上边的行循环 i = j = n while j < cols: rec.append(matrix[i][j]) # print(matrix[i][j]) j += 1 # 最右边的列循环 j -= 1 i += 1 while i < rows: rec.append(matrix[i][j]) # print(matrix[i][j]) i += 1 # 最下面的行循环 i -= 1 while j > n: j -= 1 rec.append(matrix[i][j]) # print(matrix[i][j]) # 最左边的列循环 while i > n+1: i -= 1 rec.append(matrix[i][j]) # print(matrix[i][j]) rows -= 1 cols -= 1 return rec

  

转载于:https://www.cnblogs.com/mengxiangtiankongfenwailan/p/8761405.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值