面试经典150题——Day35

文章目录

一、题目

54. Spiral Matrix

Given an m x n matrix, return all elements of the matrix in spiral order.

Example 1:

Input: matrix = \[1,2,3,4,5,6,7,8,9]

Output: 1,2,3,6,9,8,7,4,5

Example 2:

Input: matrix = \[1,2,3,4,5,6,7,8,9,10,11,12]

Output: 1,2,3,4,8,12,11,10,9,5,6,7

Constraints:

m == matrix.length

n == matrixi.length

1 <= m, n <= 10

-100 <= matrixij <= 100

二、题解

确定边界,进行模拟

cpp 复制代码
class Solution {
public:
    vector<int> spiralOrder(vector<vector<int>>& matrix) {
        int m = matrix.size();
        int n = matrix[0].size();
        vector<int> res;
        //左边界,右边界,上边界,下边界
        int left = 0,right = n - 1,up = 0,down = m - 1;
        while(true){
            //从左到右
            for(int j = left;j <= right;j++) res.push_back(matrix[up][j]);
            //上边界下移
            if(++up > down) break;
            //从上到下
            for(int i = up;i <= down;i++) res.push_back(matrix[i][right]);
            //右边界左移
            if(--right < left) break;
            //从右到左
            for(int j = right;j >= left;j--) res.push_back(matrix[down][j]);
            //下边界上移
            if(--down < up) break;
            //从下到上
            for(int i = down;i >= up;i--) res.push_back(matrix[i][left]);
            //左边界右移
            if(++left > right) break;
        }
        return res;
    }
};
相关推荐
随意起个昵称15 小时前
线性dp-综合刷题1(Not Alone)
算法·动态规划
玖玥拾15 小时前
C/C++ 基础笔记(十一)类的进阶
c语言·c++·设计模式·
-森屿安年-15 小时前
1137. 第 N 个泰波那契数
c++·动态规划
Lyyaoo.16 小时前
【数据结构】HashMap底层存储+扩容机制+线程安全【待更新】
数据结构·安全·哈希算法
如何原谅奋力过但无声16 小时前
【灵神高频面试题合集09-13】二叉树、二叉搜索树
数据结构·算法·leetcode
程序员老舅16 小时前
从内核视角,看Linux文件读写过程
linux·服务器·c++·内核·linux内核·vfs·linux内存
皆圥忈16 小时前
磁盘物理结构与文件系统基础讲解
linux·算法
数据仓库搬砖人16 小时前
用 LangGraph 从零搭一个客服 Agent:多轮对话 + 工具调用全流程
算法
GuWenyue16 小时前
告别JS类型坑!Ts为什么在ai时代逐渐成为"第一"语言
前端·算法·typescript
子琦啊16 小时前
哈希与前缀和
算法·哈希算法