算法练习:19.JZ29 顺时针打印矩阵

错误原因
  • 总体思路有,但不够清晰,一直在边调试边完善。
  • 这方面就养成更好的构思习惯,以及涨涨经验吧。
分析:
思路:找规律

两个坑:

  • 一次循环的后半段是倒着遍历的
  • 是矩阵不是方阵,要考虑行列不同的情况

特殊情况:

  1. 空矩阵
  2. 行向量,列向量
c++ 复制代码
#include <type_traits>
class Solution {
  public:
    vector<int> printMatrix(vector<vector<int> > matrix) {
        vector<int> results;
        // Step0.特殊情况处理:空矩阵
        if (matrix.size() < 1) return results;

        // Step1.计算左上,右上,左下的下标
        int k = 0;  // 左上角的下标,每次循环后+1
        int w_last = matrix[0].size() - 1; // 右上角的下标,每次循环后-1
        int h_last = matrix.size() - 1; // 左下角的下标,每次循环后-1

        while (k <= h_last && k <= w_last) { // 本次循环的左上角与右上角重合后 or 左上角与左下角重合后
            // Step1.顺序遍历上面一行
            for (int j = k; j <= w_last; j++)
                results.push_back(matrix[k][j]);

            // Step2.顺序遍历右边一行
            for (int i = k + 1; i <= h_last - 1; i++)
                results.push_back(matrix[i][w_last]);

            // Step3.逆序遍历下面一行
            if (k < h_last) // 跳出条件:左上角与左下角重合(针对矩阵非方阵的情况,包括行向量)
                for (int j = w_last; j >= k; j--)
                    results.push_back(matrix[h_last][j]);

            // Step4.逆序遍历左边一行
            if (k < w_last) // 跳出条件:左上角与右上角重合(针对矩阵非方阵的情况,包括列向量)
                for (int i = h_last - 1; i >= k + 1; i--)
                    results.push_back(matrix[i][k]);
            k++;
            w_last--;
            h_last--;
        }
        return results;
    }
};
相关推荐
纪元A梦3 小时前
贪心算法应用:化工反应器调度问题详解
算法·贪心算法
深圳市快瞳科技有限公司3 小时前
小场景大市场:猫狗识别算法在宠物智能设备中的应用
算法·计算机视觉·宠物
liulilittle4 小时前
OPENPPP2 —— IP标准校验和算法深度剖析:从原理到SSE2优化实现
网络·c++·网络协议·tcp/ip·算法·ip·通信
superlls6 小时前
(算法 哈希表)【LeetCode 349】两个数组的交集 思路笔记自留
java·数据结构·算法
田里的水稻6 小时前
C++_队列编码实例,从末端添加对象,同时把头部的对象剔除掉,中的队列长度为设置长度NUM_OBJ
java·c++·算法
纪元A梦6 小时前
贪心算法应用:保险理赔调度问题详解
算法·贪心算法
Jayden_Ruan7 小时前
C++逆向输出一个字符串(三)
开发语言·c++·算法
点云SLAM8 小时前
C++ 常见面试题汇总
java·开发语言·c++·算法·面试·内存管理
叙白冲冲8 小时前
哈希算法以及面试答法
算法·面试·哈希算法
YuTaoShao9 小时前
【LeetCode 每日一题】1277. 统计全为 1 的正方形子矩阵
算法·leetcode·矩阵