每日一练(17):顺时针打印矩阵

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

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


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


来源:力扣(LeetCode)


链接:https://leetcode-cn.com/probl...


方法:设定边界


根据题目示例 matrix = [[1,2,3],[4,5,6],[7,8,9]] 的对应输出 [1,2,3,6,9,8,7,4,5] 可以发现,顺时针打印矩阵的顺序是 “从左向右、从上向下、从右向左、从下向上” 循环。


因此,考虑设定矩阵的“左、上、右、下”四个边界,模拟以上矩阵遍历顺序。


算法流程:


1.空值处理: 当 matrix 为空时,直接返回空列表 [] 即可。

2.初始化: 矩阵 左、右、上、下 四个边界 l , r , t , b ,用于打印的结果列表 res 。

3.循环打印: “从左向右、从上向下、从右向左、从下向上” 四个方向循环,每个方向


打印中做以下三件事 (各方向的具体信息见下表) ;


  • 1.根据边界打印,即将元素按顺序添加至列表 res 尾部;
  • 2.边界向内收缩 11 (代表已被打印);
  • 3.判断是否打印完毕(边界是否相遇),若打印完毕则跳出。
  • 4.返回值: 返回 res 即可。


打印方向 1. 根据边界打印 2. 边界向内收缩 3. 是否打印完毕
从左向右 左边界 l ,右边界 r 上边界 t 加 1 是否 t > b
从上向下 上边界 t ,下边界 b 右边界 r 减 1 是否 l > r
从右向左 右边界 r ,左边界 l 下边界 b 减 1 是否 t > b
从下向上 下边界 b ,上边界 t 左边界 l 加 1 是否 l > r


复杂度分析:


  • 时间复杂度 O(MN) : M,N 分别为矩阵行数和列数。
  • 空间复杂度 O(1) : 四个边界 l , r , t , b 使用常数大小的 额外 空间( res 为必须使用的空间)。


vector<int> spiralOrder(vector<vector<int>>& matrix) {
    if (matrix.empty()) {
        return {};
    }
    vector<int> res;
    int l = 0;                      //左边界
    int r = matrix[0].size() - 1;   //右边界
    int t = 0;                      //上边界
    int b = matrix.size() - 1;      //下边界
    while (true) {
        //left -> right
        for (int i = l; i <= r; i++) {
            res.push_back(matrix[t][i]);
        }
        if (++t > b) {
            break;
        }
        //top -> bottom
        for (int i = t; i <= b; i++) {
            res.push_back(matrix[i][r]);
        }
        if (--r < l) {
            break;
        }
        //right -> left
        for (int i = r; i >= l; i--) {
            res.push_back(matrix[b][i]);
        }
        if (--b < t) {
            break;
        }
        //bottom -> top
        for (int i = b; i >= t; i--) {
            res.push_back(matrix[i][l]);
        }
        if (++l > r) {
            break;
        }
    }
    return res;
}


目录
相关文章
|
弹性计算 Ubuntu 安全
基于Ubuntu20.4搭建WordPress个人博客
在Ubuntu20.4系统上成功搭建了WordPress个人博客并且对WordPress进行了简单的配置。
1485 2
基于Ubuntu20.4搭建WordPress个人博客
|
1月前
|
SQL 监控 关系型数据库
一键开启百倍加速!RDS DuckDB 黑科技让SQL查询速度最高提升200倍
RDS MySQL DuckDB分析实例结合事务处理与实时分析能力,显著提升SQL查询性能,最高可达200倍,兼容MySQL语法,无需额外学习成本。
|
11月前
|
自然语言处理 API C++
阿里通义推出SmartVscode插件,自然语言控制VS Code,轻松开发应用,核心技术开源!
SmartVscode插件深度解析:自然语言控制VS Code的革命性工具及其开源框架App-Controller
1570 1
阿里通义推出SmartVscode插件,自然语言控制VS Code,轻松开发应用,核心技术开源!
|
前端开发 安全 JavaScript
Python的Flask框架的学习笔记(前后端变量传送,文件上传,网页返回)内含实战:实现一个简单的登录页面
Python的Flask框架的学习笔记(前后端变量传送,文件上传,网页返回)内含实战:实现一个简单的登录页面
432 0
|
9月前
|
机器学习/深度学习 人工智能 算法
《片上网络,如何让硬件加速系统通信“快人一步”》
片上网络(NoC)作为提升硬件加速系统通信效率的核心技术,正逐渐成为科技领域的焦点。它借鉴计算机网络概念,在芯片内构建复杂高效的通信网络,确保各组件间信息快速传递。NoC通过节点和链路组成,采用不同拓扑结构优化性能,如网状、环形等。高效路由算法、流量控制机制及拓扑结构优化是其关键技术,旨在解决带宽瓶颈、延迟等问题,推动人工智能和高性能计算发展。
239 14
|
机器学习/深度学习
回归预测 | MATLAB实现GRNN广义回归神经网络多输入多输出预测
回归预测 | MATLAB实现GRNN广义回归神经网络多输入多输出预测
|
canal 存储 Kubernetes
Kubernetes 之7大CNI 网络插件用法和对比
的通信,支持多种网络后端,如 VXLAN、UDP 和 Host-GW。 Calico:Calico 是一种基于 BGP 的网络插件,它使用路由表来路由容器之间的流量,支持多种网络拓扑结构,并提供了安全性和网络策略功能。 Canal:Canal 是一个组合了 Flannel 和 Calico 的网络插件,它使用 Flannel 来提供容器之间的通信,同时使用 Calico 来提供网络策略和安全性功能。 Weave Net:Weave Net 是一种轻量级的网络插件,它使用虚拟网络技术来为容器提供 IP 地址,并支持多种网络后端,如 VXLAN、UDP 和 TCP/IP,同时还提供了网络策略
7661 0
|
存储 JSON 关系型数据库
MySQL 8.0 功能特性
MySQL 作为最流行的开源关系型数据库管理系统之一,不断推陈出新,满足用户不断增长的需求和期望。在本篇博客中,我们将探讨 MySQL 8.0 版本带来的一些令人振奋的功能特性。
359 0
|
存储 监控 Java
【SpringBoot技术专题】「StateMachine」状态机设计及实现
【SpringBoot技术专题】「StateMachine」状态机设计及实现
2869 0
【SpringBoot技术专题】「StateMachine」状态机设计及实现