剑指 Offer 29. 顺时针打印矩阵

输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。

示例 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]

限制:

0 <= matrix.length <= 100

0 <= matrix[i].length <= 100

思路:首先自己在33和4 4的数组中尝试螺旋遍历,会发现规律。

当向右遍历时,其实是从上到下遍历行。rowBegin -》 rowEnd

当向下遍历时,其实是从右到左遍历列。colEnd -》 colBegin

当向左遍历时,其实是从下到上遍历行。rowEnd -》 rowBegin

当向上遍历时,其实是从左到右遍历列。 colBegin -》 colEnd

cpp 复制代码
class Solution {
public:
    vector<int> spiralOrder(vector<vector<int>>& matrix) {
        vector<int> result; // 存储结果的向量

        if (matrix.empty()) // 如果矩阵为空,直接返回结果向量
            return result;

        // 定义边界变量
        int rowBegin = 0; // 行的起始位置
        int colBegin = 0; // 列的起始位置
        int rowEnd = matrix.size() - 1; // 行的结束位置
        int colEnd = matrix[0].size() - 1; // 列的结束位置

        // 不断缩小边界进行遍历,直到边界重合或交错
        while(rowBegin <= rowEnd && colBegin <= colEnd) {
            // 从左到右遍历当前行
            for (int i = colBegin; i <= colEnd; i++) {
                result.push_back(matrix[rowBegin][i]); // 将当前元素添加到结果向量
            }
            rowBegin++; // 增加起始行索引,排除已遍历的行

            // 从上到下遍历当前列
            for (int i = rowBegin; i <= rowEnd; i++) {
                result.push_back(matrix[i][colEnd]); // 将当前元素添加到结果向量
            }
            colEnd--; // 减少结束列索引,排除已遍历的列

            // 从右到左遍历当前行
            if (rowBegin <= rowEnd) { // 检查是否还有剩余的行未遍历
                for (int i = colEnd; i >= colBegin; i--) {
                    result.push_back(matrix[rowEnd][i]); // 将当前元素添加到结果向量
                }
                rowEnd--; // 减少结束行索引,排除已遍历的行
            }

            // 从下到上遍历当前列
            if (colBegin <= colEnd) { // 检查是否还有剩余的列未遍历
                for (int i = rowEnd; i >= rowBegin; i--) {
                    result.push_back(matrix[i][colBegin]); // 将当前元素添加到结果向量
                }
                colBegin++; // 增加起始列索引,排除已遍历的列
            }
        }

        return result; // 返回结果向量
    }
};
相关推荐
cici158745 分钟前
经典的基于策略迭代和值迭代法的动态规划MATLAB实现
算法·matlab·动态规划
月明长歌6 分钟前
【码道初阶-Hot100】 LeetCode 49. 字母异位词分组:从排序哈希到分组映射,彻底讲透为什么排序后可以作为同一组的标识
算法·leetcode·哈希算法
Q一件事12 分钟前
结构方程相关
python·算法·机器学习
yugi98783812 分钟前
兰伯特问题求解的MATLAB实现
开发语言·算法·matlab
小年糕是糕手13 分钟前
【35天从0开始备战蓝桥杯 -- Day4】
数据结构·c++·算法·leetcode·蓝桥杯
xiaoye-duck14 分钟前
《算法题讲解指南:递归,搜索与回溯算法--递归》--1.汉诺塔,2.合并两个有序链表
数据结构·c++·算法
故以往之不谏16 分钟前
算法专题--数组二分查找--Leetcode704题
c语言·开发语言·c++·算法·新人首发
C+-C资深大佬21 分钟前
C++ 模板进阶
开发语言·c++·算法
无尽的罚坐人生23 分钟前
hot 100 98. 验证二叉搜索树
算法·leetcode
liu-yonggang36 分钟前
ROS2 性能优化与功能增强方案
大数据·算法·性能优化