算法练习: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;
    }
};
相关推荐
j44556611几秒前
C++中的备忘录模式
开发语言·c++·算法
m0_603888712 分钟前
POP Prefill-Only Pruning for Efficient Large Model Inference
算法·机器学习·ai·剪枝·论文速览
近津薪荼3 分钟前
dfs专题——二叉树的深搜3(二叉树剪枝)
c++·学习·算法·深度优先
拼好饭和她皆失3 分钟前
数学知识:约数的详细解析
算法·数论
伯明翰java4 分钟前
排序算法(1)
算法·排序算法
啊阿狸不会拉杆6 分钟前
《机器学习导论》第 2 章-监督学习
数据结构·人工智能·python·学习·算法·机器学习·监督学习
乌萨奇也要立志学C++7 分钟前
【洛谷】记忆化搜索 原理剖析与经典例题详解
算法·深度优先
Code920077 分钟前
洛谷P3514 [POI 2011] LIZ-Lollipop(思维题)
算法
m0_706653239 分钟前
C++中的解释器模式
开发语言·c++·算法
We་ct12 分钟前
LeetCode 202. 快乐数:题解+思路拆解
前端·算法·leetcode·typescript