LeetCode热题100 螺旋矩阵

题目描述

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

示例 1:


输入: matrix = [[1,2,3],[4,5,6],[7,8,9]]
输出: [1,2,3,6,9,8,7,4,5]

示例 2:


输入: matrix = [[1,2,3,4],[5,6,7,8],[9,10,11,12]]
输出: [1,2,3,4,8,12,11,10,9,5,6,7]

提示:

m == matrix.length

n == matrix[i].length

1 <= m, n <= 10

-100 <= matrix[i][j] <= 100

思路

1 定义dx和dy数组代表4个方向。

2 定义times数组代表有n行和m列。

3 每次走完一个方向,会有一行减去或者一列减去。

4 模拟走完这个过程即可。

代码

cpp 复制代码
class Solution {
public:
    vector<int> spiralOrder(vector<vector<int>>& matrix) {
    	int n = matrix.size();
    	int m = matrix[0].size();
    	int dx[] = {0, 1, 0, -1}, dy[]= {1, 0, -1, 0}; // 方向 
    	int times[] = {m, n}; // 行和列的大小 
        vector<int>ans; // 答案
		int x = 0, y = -1, pos = 0 ; // x和y初始化坐标, pos代表方向和行列
        while(ans.size() < n * m)
        {
        	for(int i = 0; i < times[pos % 2]; ++i)
			{
				x += dx[pos];
				y += dy[pos];	
				ans.push_back(matrix[x][y]);
			}	
			pos = (pos + 1) % 4;
			--times[pos % 2] ;
		}    
		return ans; 
	}	
};
相关推荐
_深海凉_1 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
踩坑记录2 小时前
leetcode hot100 寻找两个正序数组的中位数 hard 二分查找 双指针
leetcode
旖-旎2 小时前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历
谭欣辰2 小时前
C++快速幂完整实战讲解
算法·决策树·机器学习
Mr_pyx2 小时前
【LeetHOT100】随机链表的复制——Java多解法详解
算法·深度优先
AIFarmer3 小时前
【无标题】
开发语言·c++·算法
AGV算法笔记3 小时前
CVPR 2025 最新感知算法解读:GaussianLSS 如何用 Gaussian Splatting 重构 BEV 表示?
算法·重构·自动驾驶·3d视觉·感知算法·多视角视觉
勤劳的进取家4 小时前
数据链路层基础
网络·学习·算法
Advancer-4 小时前
第二次蓝桥杯总结(上)
java·算法·职场和发展·蓝桥杯
ん贤5 小时前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法