算法练习: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;
    }
};
相关推荐
云在Steven35 分钟前
在线确定性算法与自适应启发式在虚拟机动态整合中的竞争分析与性能优化
人工智能·算法·性能优化
前进的李工1 小时前
LeetCode hot100:234 回文链表:快慢指针巧判回文链表
python·算法·leetcode·链表·快慢指针·回文链表
sin_hielo1 小时前
leetcode 3228
算法·leetcode
xier_ran2 小时前
力扣(LeetCode)100题:41.缺失的第一个正数
数据结构·算法·leetcode
Swift社区2 小时前
LeetCode 425 - 单词方块
算法·leetcode·职场和发展
weixin_307779133 小时前
软件演示环境动态扩展与成本优化:基于目标跟踪与计划扩展的AWS Auto Scaling策略
算法·云原生·云计算·aws
Carl_奕然3 小时前
【机器视觉】一文掌握常见图像增强算法。
人工智能·opencv·算法·计算机视觉
放羊郎3 小时前
人工智能算法优化YOLO的目标检测能力
人工智能·算法·yolo·视觉slam·建图
无敌最俊朗@4 小时前
友元的作用与边界
算法
Miraitowa_cheems4 小时前
LeetCode算法日记 - Day 104: 通配符匹配
linux·数据结构·算法·leetcode·深度优先·动态规划