给你一个大小为 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]
提示:
m == mat.length
n == mat[i].length
1 <= m, n <= 104
1 <= m * n <= 104
-105 <= mat[i][j] <= 105
法一:先算上三角,下三角还没想起来怎么整...感觉有点难度,右下部分没法这样写了,最后只对了一半
class Solution(object):
def findDiagonalOrder(self, mat):
"""
:type mat: List[List[int]]
:rtype: List[int]
"""
i=len(mat)
j=len(mat[0])
k=i
t=[]
for s in range(1,k+1):
p=s-1
if s%2==1:
for m in range(s):
t.append(mat[p][m])
if p>=1:
p-=1
if s%2==0:
for m in range(s):
t.append(mat[m][p])
if p>=1:
p-=1
return t
这段代码是一个用于按对角线顺序遍历二维数组的函数。以下是对代码的解释:
- 第7行获取二维数组的行数 `i`, 第8行获取二维数组的列数 `j`。
- 第9行设置循环变量 `k` 为行数 `i`。
- 第10行创建一个空列表 `t`,用于存储按对角线顺序遍历的元素。
- 在循环中,从第1行到第 `k` 行逐次遍历,并使用变量 `s` 表示当前遍历的行数(从1开始)。
- 在奇数轮次(如果 `s%2==1`),从当前列号 `p` 开始遍历该对角线,递减列号并将对应位置的元素添加到列表 `t` 中。遍历到第一行时退出内循环。对角线遍历方向是从上到下。
- 在偶数轮次(如果 `s%2==0`),从当前行号 `m` 开始遍历该对角线,递减行号并将对应位置的元素添加到列表 `t` 中。遍历到第一列时退出内循环。对角线遍历方向是从左到右。
- 最后返回列表 `t`,即按对角线顺序遍历的元素列表。
请注意,这段代码只考虑了 `mat` 是非空二维数组的情况。在实际使用时,还需要根据需求进行适当的输入检查和边界处理。