leetcode54螺旋矩阵题解

简介: leetcode54螺旋矩阵题解

LC54螺旋矩阵I

给你一个 mn 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。

输入:matrix = [[1,2,3],[4,5,6],[7,8,9]]
输出:[1,2,3,6,9,8,7,4,5]
class Solution {
   
public:
    vector<int> spiralOrder(vector<vector<int>>& matrix) {
   
        if(matrix.empty())return{
   };
        int r=matrix[0].size()-1;
        int b=matrix.size()-1;
        int l=0,t=0;
        vector<int>res;
        while(1){
   
            for(int i=l;i<=r;i++)res.push_back(matrix[t][i]);//左到右
            if(++t>b)break;
            for(int i=t;i<=b;i++)res.push_back(matrix[i][r]);//上到下
            if(--r<l)break;
            for(int i=r;i>=l;i--)res.push_back(matrix[b][i]);//右到左
            if(--b<t)break;
            for(int i=b;i>=t;i--)res.push_back(matrix[i][l]);//下到上
            if(++l>r)break;
        }
        return res;
    }
};
目录
相关文章
|
11月前
【Leetcode -2181.合并零之间的节点- 2326.螺旋矩阵Ⅳ】
【Leetcode -2181.合并零之间的节点- 2326.螺旋矩阵Ⅳ】
67 0
|
1月前
|
算法
LeetCode第59题螺旋矩阵 II
LeetCode第59题"螺旋矩阵 II"的解题方法,通过模拟螺旋填充过程,一圈一圈从外到内按顺序填充数字,直到完成整个矩阵的构建。
LeetCode第59题螺旋矩阵 II
|
1月前
|
存储 算法
LeetCode第54题螺旋矩阵
LeetCode第54题"螺旋矩阵"的解题方法,通过模拟从外到内的螺旋遍历过程,并利用方向向量控制遍历方向的转换,有效输出矩阵的螺旋顺序。
LeetCode第54题螺旋矩阵
|
11月前
|
机器学习/深度学习 算法
代码随想录Day02 数组基础2 leetcode T977有序数组的平方, T209 长度最小的子数组,T59 螺旋矩阵II
代码随想录Day02 数组基础2 leetcode T977有序数组的平方, T209 长度最小的子数组,T59 螺旋矩阵II
51 0
|
3月前
|
算法 机器人 数据挖掘
LeetCode题目54:螺旋矩阵【python4种算法实现】
LeetCode题目54:螺旋矩阵【python4种算法实现】
|
3月前
|
存储 算法
力扣经典150题第三十五题:螺旋矩阵
力扣经典150题第三十五题:螺旋矩阵
15 0
|
4月前
leetcode-6111:螺旋矩阵 IV
leetcode-6111:螺旋矩阵 IV
39 0
|
4月前
|
Java C++ Python
leetcode-59:螺旋矩阵 II
leetcode-59:螺旋矩阵 II
29 0
|
4月前
leetcode-54:螺旋矩阵
leetcode-54:螺旋矩阵
34 0
LeetCode刷题Day03——数组(滑动窗口+螺旋矩阵)
所谓滑动窗口,就是不断的调节子序列的起始位置和终止位置,从而得出我们要想的结果。 滑动窗口也可以理解为双指针法的一种,只不过这种解法更像是一个窗口的移动。 实现滑动窗口,主要确定如下三点: