leetcode日记(42)螺旋矩阵

我使用的是递归,每次递归遍历一圈矩阵,将遍历结果塞进结果vector中,每次遍历修改上下左右边界,直至遍历后其中两边界重合或交错。

cpp 复制代码
class Solution {
public:
    vector<int> spiralOrder(vector<vector<int>>& matrix) {
        int m=matrix.size();
        int n=matrix[0].size();
        vector<int> result;
        Order(result,matrix,m-1,n-1,0,0);
        return result;
    }
    void Order(vector<int> &result,vector<vector<int>> matrix,int m,int n,int mm,int nn){
        if(mm==nn&&m==n&&mm==m) {result.push_back(matrix[mm][nn]);return ;}
        if(mm==m) {for(int i=nn;i<=n;i++) result.push_back(matrix[mm][i]);return ;}
        if(nn==n) {for(int i=mm;i<=m;i++) result.push_back(matrix[i][n]);return ;}
        for(int i=nn;i<n;i++) result.push_back(matrix[mm][i]);
        for(int i=mm;i<m;i++) result.push_back(matrix[i][n]);
        for(int i=n;i>nn;i--) result.push_back(matrix[m][i]);
        for(int i=m;i>mm;i--) result.push_back(matrix[i][nn]);
        if(mm==m-1||nn==n-1) return ;
        if(m>mm&&n>nn) Order(result,matrix,m-1,n-1,mm+1,nn+1);
    }
};
相关推荐
AI科技星8 小时前
统一场论质量定义方程:数学验证与应用分析
开发语言·数据结构·经验分享·线性代数·算法
咚咚王者12 小时前
人工智能之数学基础 线性代数:第二章 向量空间
人工智能·线性代数
元周民13 小时前
非厄米矩阵高精度计算预先判定需要的计算精度(matlab)
线性代数·matlab·矩阵
java修仙传13 小时前
力扣hot100:搜索二维矩阵
算法·leetcode·矩阵
浅川.2515 小时前
xtuoj 矩阵
线性代数·矩阵
ACERT33315 小时前
05-矩阵理论复习第五章 向量与矩阵范数
python·算法·矩阵
前端小白在前进17 小时前
⭐力扣刷题:螺旋矩阵
算法·leetcode·矩阵
-一杯为品-1 天前
【机器人学|运动学与动力学】#1 齐次变换矩阵
线性代数·矩阵
胖咕噜的稞达鸭2 天前
算法入门:专题前缀和:一二维前缀和 寻找数组的中心下标 除自身以外数组的乘积 和为k的子数组 和可被k整除的子数组 连续数组 矩阵区域和
线性代数·算法·矩阵
拾贰_C2 天前
【数学 | 大学数学 | 考研数学 | 计算机】线性代数 | 矩阵论
线性代数·矩阵