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);
    }
};
相关推荐
Smilecoc6 小时前
求极限中等价无穷小量的替换的理解
线性代数·概率论
Physicist in Geophy.7 小时前
矩阵 与 算子
矩阵·算子
minglie17 小时前
倒立摆模型
线性代数
sunfove8 小时前
Python制作小游戏:用线性代数思想构建 2048 游戏引擎
python·线性代数·游戏引擎
Swift社区8 小时前
LeetCode 378 有序矩阵中第 K 小的元素
算法·leetcode·矩阵
Physicist in Geophy.8 小时前
函数,矩阵 算子 泛函
矩阵
sonadorje8 小时前
矩阵的“秩”是什么?
算法·机器学习·矩阵
好奇龙猫8 小时前
【大学院-筆記試験練習:线性代数和数据结构(12)】
数据结构·线性代数
geffen16888 小时前
支持语音识别并控制的混合高清矩阵:革新视听体验,开启智能控制新时代
人工智能·矩阵·语音识别
Physicist in Geophy.9 小时前
矩阵的本质
算法·机器学习·矩阵