LeetCode 刷题 [C++] 第54题.螺旋矩阵

题目描述

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

题目分析

  1. 根据题意可知,我们不需要记录已经走过的路径,只需要通过调整矩阵的上下左右边界即可完成任务;
  2. 首先创建出矩阵的上下左右边界;
  3. 开始遍历矩阵:
    先从左上角,从左向右遍历第一行,然后删除第一行,即重新定义上边界;
    然后判断重新定义后的上下边界是否交错,如果交错,则表示螺旋矩阵遍历结束,跳出循环,返回数组;
    如果重新定义后的边界没有交错,则接着遍历矩阵;
  4. 使用3中类似的逻辑接着向下向左向上移动;
  5. 不断循环步骤3和4,直至某两个边界交错,跳出循环为止,最后返回结果。

Code

cpp 复制代码
class Solution {
public:
    vector<int> spiralOrder(vector<vector<int>>& matrix) {
        if (matrix.empty()) return {};
        vector<int> res;
        res.reserve(matrix.size()*matrix[0].size()); //预分配容器的大小
        int upper = 0, down = matrix.size() - 1;
        int left = 0, right = matrix[0].size() - 1;
        while (true) {
        	// 向右遍历
            for (int i = left; i <= right; ++i) {
                res.emplace_back(matrix[upper][i]);
            }
            if (++upper > down) {
                break;
            }
			// 向下遍历
            for (int i = upper; i <= down; ++i){
                res.emplace_back(matrix[i][right]);
            }
            if (--right < left) {
                break;
            }
			// 向左遍历
            for (int i = right; i >= left; --i) {
                res.emplace_back(matrix[down][i]);
            }
            if (--down < upper) {
                break;
            }
			// 向上遍历
            for (int i = down; i >= upper; --i) {
                res.emplace_back(matrix[i][left]);
            }
            if (++left > right) {
                break;
            }
        }
        return res;
    }
};
相关推荐
Tisfy29 分钟前
LeetCode 2615.等值距离和:分组(哈希表+前缀和)
算法·leetcode·散列表
小此方35 分钟前
Re:从零开始的 C++ 进阶篇(四)工业级 C++ 编程:如何构建异常安全的健壮系统?(含案例分析)
运维·开发语言·c++·安全
电商API_1800790524738 分钟前
如何实现批量化自动化获取淘宝商品详情数据?爬虫orAPI?
大数据·c++·爬虫·自动化
t***54443 分钟前
如何确认 Clang 是否在 Dev-C++ 中成功应用
java·开发语言·c++
楚Y6同学1 小时前
QT之下拉框自动填充功能
开发语言·c++·qt·qt开发技巧·串口下拉填充·网口下拉填充
视***间1 小时前
小而强筑内核,智无界启新程 —— 视程空间全栈硬件产品矩阵,赋能千行百业边缘智能升级
人工智能·矩阵·边缘计算·视程空间·终端算力·nvidia jetson
mjhcsp1 小时前
根号快速计算牛顿迭代法
开发语言·c++·算法·迭代法
菜鸟丁小真1 小时前
LeetCode hot100-79.单词搜索
数据结构·算法·leetcode·深度优先·知识总结
Tisfy1 小时前
LeetCode 2833.距离原点最远的点:计数
算法·leetcode·字符串·题解·模拟·计数
小小de风呀1 小时前
de风——【从零开始学C++】(二):类和对象入门(一)
开发语言·c++