LeetCode/对角线遍历
给你一个大小为 m x n 的矩阵 mat ,请以对角线遍历的顺序,用一个数组返回这个矩阵中的所有元素
1. 模拟操作
按照对角线扫描的顺序,首先要清楚得遍历m+n-1趟
对于对角线移动操作,往上扫描时横坐标增,纵坐标减,往下扫描时,横坐标减,纵坐标增
每扫描完一趟,横纵坐标有一个变化
向上扫描结束时,如果不为右边界,则纵坐标不变,横坐标加1,否则横坐标不变,纵坐标加1
向下扫描结束时,如果不为下边界,则横坐标不变,纵坐标加1,否则纵坐标不变,横坐标加1
在边界的时候,坐标初始值可以根据趟数计算得到
class Solution {
public:
vector<int> findDiagonalOrder(vector<vector<int>>& mat) {
int m = mat.size();
int n = mat[0].size();
vector<int> res;
for (int i = 0; i < m + n - 1; i++) {
if (i % 2) {//从上往下
int x = i < n ? 0 : i - n + 1;//不为右边界,纵坐标为0,否则通过趟数运算
int y = i - x;
while (x < m && y >= 0) {
res.emplace_back(mat[x][y]);
x++;
y--;
}
} else {//从下往上
int x = i < m ? i : m - 1;//不为下边界,纵坐标为趟数,否则为m-1
int y = i - x;
while (x >= 0 && y < n) {
res.emplace_back(mat[x][y]);
x--;
y++;
}
}
}
return res;
}
};