对角线遍历

给你一个大小为 m x n 的矩阵 mat ,请以对角线遍历的顺序,用一个数组返回这个矩阵中的所有元素。

示例 1:

对角线遍历_第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





对角线遍历_第2张图片

这段代码是一个用于按对角线顺序遍历二维数组的函数。以下是对代码的解释:

- 第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` 是非空二维数组的情况。在实际使用时,还需要根据需求进行适当的输入检查和边界处理。

你可能感兴趣的:(python,数据结构,leetcode)