算法练习: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;
    }
};
相关推荐
金融小师妹2 小时前
应用BERT-GCN跨模态情绪分析:贸易缓和与金价波动的AI归因
大数据·人工智能·算法
广州智造2 小时前
OptiStruct实例:3D实体转子分析
数据库·人工智能·算法·机器学习·数学建模·3d·性能优化
Trent19854 小时前
影楼精修-肤色统一算法解析
图像处理·人工智能·算法·计算机视觉
feifeigo1234 小时前
高光谱遥感图像处理之数据分类的fcm算法
图像处理·算法·分类
.格子衫.6 小时前
真题卷001——算法备赛
算法
XiaoyaoCarter6 小时前
每日一道leetcode
c++·算法·leetcode·职场和发展·二分查找·深度优先·前缀树
Hygge-star7 小时前
【数据结构】二分查找5.12
java·数据结构·程序人生·算法·学习方法
June`8 小时前
专题二:二叉树的深度搜索(二叉树剪枝)
c++·算法·深度优先·剪枝
好吃的肘子9 小时前
Elasticsearch架构原理
开发语言·算法·elasticsearch·架构·jenkins