【数组】498. 对角线遍历
【摘要】 【题目】给你一个大小为 m x n 的矩阵 mat ,请以对角线遍历的顺序,用一个数组返回这个矩阵中的所有元素。 示例 1:输入:mat = [[1,2,3],[4,5,6],[7,8,9]]输出:[1,2,4,7,5,3,6,8,9]示例 2:输入:mat = [[1,2],[3,4]]输出:[1,2,3,4]【题解】题解1:思路 看注释复杂度 时间复杂度:O(...
【题目】
给你一个大小为 m x n
的矩阵 mat
,请以对角线遍历的顺序,用一个数组返回这个矩阵中的所有元素。
示例 1:
输入:mat = [[1,2,3],[4,5,6],[7,8,9]]
输出:[1,2,4,7,5,3,6,8,9]
示例 2:
输入:mat = [[1,2],[3,4]]
输出:[1,2,3,4]
【题解】
题解1:
- 思路
看注释
- 复杂度
时间复杂度:O(n),空间复杂度:O(1)
- 代码
class Solution:
def findDiagonalOrder(self, mat: List[List[int]]) -> List[int]:
ans = []
# 矩阵m,n
m, n = len(mat), len(mat[0])
# 第n条对角线
for i in range(m + n - 1):
# 当n为偶数时从下往上
if i % 2:
# 起始点
x = 0 if i < n else i - n + 1
y = i if i < n else n - 1
while x < m and y >= 0:
ans.append(mat[x][y])
x += 1
y -= 1
# 当n为奇数时从上往下
else:
# 起始点
x = i if i < m else m - 1
y = 0 if i < m else i - m + 1
while x >= 0 and y < n:
ans.append(mat[x][y])
x -= 1
y += 1
return ans
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)