当前位置: 首页 > news >正文

力扣最热一百题——螺旋矩阵

目录

题目链接:54. 螺旋矩阵 - 力扣(LeetCode)

题目描述

示例

提示:

解法一:模拟

1. 边界初始化

2. 循环遍历矩阵

3. 从左到右遍历上边界

4. 从上到下遍历右边界

5. 从右到左遍历下边界

6. 从下到上遍历左边界

7. 结束条件

代码执行流程总结

Java写法:

运行时间以及内存消耗

C++写法:

运行时间以及内存消耗

总结


题目链接:54. 螺旋矩阵 - 力扣(LeetCode)

注:下述题目描述和示例均来自力扣

题目描述

给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。

示例

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

提示:

  • m == matrix.length
  • n == matrix[i].length
  • 1 <= m, n <= 10
  • -100 <= matrix[i][j] <= 100


解法一:模拟

按照顺时针方向从外圈到内圈依次读取矩阵中的元素。具体实现思路可以分为以下几个步骤:

1. 边界初始化

  • 定义四个边界:top, bottom, left, right,分别表示矩阵的上边界、下边界、左边界和右边界。
  • 初始时,top 为 0(最上方),bottom 为矩阵的最后一行索引,left 为 0(最左边),right 为矩阵的最后一列索引。

2. 循环遍历矩阵

  • 进入 while 循环,条件是:top <= bottom && left <= right。这意味着当矩阵还未完全遍历时,继续循环。
  • 在每次循环中,按照四个方向依次遍历:从左到右、从上到下、从右到左、从下到上。每次遍历完一条边界后,收缩该边界(即移动内圈的边界)。

3. 从左到右遍历上边界

  • 首先,遍历当前 top 行,从 leftright,将该行的所有元素依次添加到结果数组中。
  • 遍历完成后,将 top 变量加 1,表示上边界下移一行,进入内层。

4. 从上到下遍历右边界

  • 然后,遍历当前 right 列,从 topbottom,将该列的所有元素依次添加到结果数组中。
  • 遍历完成后,将 right 变量减 1,表示右边界左移一列。

5. 从右到左遍历下边界

  • 如果 top <= bottom 仍然成立(即还有未遍历的行),开始遍历 bottom 行,从 rightleft,将该行的所有元素依次添加到结果数组中。
  • 遍历完成后,将 bottom 变量减 1,表示下边界上移一行。

6. 从下到上遍历左边界

  • 如果 left <= right 仍然成立(即还有未遍历的列),开始遍历 left 列,从 bottomtop,将该列的所有元素依次添加到结果数组中。
  • 遍历完成后,将 left 变量加 1,表示左边界右移一列。

7. 结束条件

  • 循环不断缩小边界,直到 top > bottomleft > right,表示已经遍历完所有的元素,此时退出循环。
  • 返回保存螺旋顺序的 res 数组。

代码执行流程总结

  1. 每次从四个方向依次遍历矩阵的当前边界。
  2. 每遍历完一条边界,收缩该边界,进入下一层的螺旋圈。
  3. 重复上述步骤,直到所有元素都被遍历完。

Java写法:

class Solution {public List<Integer> spiralOrder(int[][] matrix) {List<Integer> res = new ArrayList<>();if (matrix == null || matrix.length == 0) {return res;}int top = 0; // 上边界int bottom = matrix.length - 1; // 下边界int left = 0; // 左边界int right = matrix[0].length - 1; // 右边界while (top <= bottom && left <= right) {// 从左到右遍历当前的上边界for (int i = left; i <= right; i++) {res.add(matrix[top][i]);}top++; // 上边界收缩// 从上到下遍历当前的右边界for (int i = top; i <= bottom; i++) {res.add(matrix[i][right]);}right--; // 右边界收缩// 判断是否还需要遍历if (top <= bottom) {// 从右到左遍历当前的下边界for (int i = right; i >= left; i--) {res.add(matrix[bottom][i]);}bottom--; // 下边界收缩}// 判断是否还需要遍历if (left <= right) {// 从下到上遍历当前的左边界for (int i = bottom; i >= top; i--) {res.add(matrix[i][left]);}left++; // 左边界收缩}}return res;}
}

 

运行时间以及内存消耗

C++写法:

#include <vector>
using namespace std;class Solution {
public:vector<int> spiralOrder(vector<vector<int>>& matrix) {vector<int> res;if (matrix.empty() || matrix[0].empty()) {return res;}int top = 0; // 上边界int bottom = matrix.size() - 1; // 下边界int left = 0; // 左边界int right = matrix[0].size() - 1; // 右边界while (top <= bottom && left <= right) {// 从左到右遍历当前的上边界for (int i = left; i <= right; i++) {res.push_back(matrix[top][i]);}top++; // 上边界收缩// 从上到下遍历当前的右边界for (int i = top; i <= bottom; i++) {res.push_back(matrix[i][right]);}right--; // 右边界收缩// 判断是否还需要遍历if (top <= bottom) {// 从右到左遍历当前的下边界for (int i = right; i >= left; i--) {res.push_back(matrix[bottom][i]);}bottom--; // 下边界收缩}// 判断是否还需要遍历if (left <= right) {// 从下到上遍历当前的左边界for (int i = bottom; i >= top; i--) {res.push_back(matrix[i][left]);}left++; // 左边界收缩}}return res;}
};
运行时间以及内存消耗


总结

这里的边界条件实在是非常的难把握,所实话,一但掉入了边界条件的陷阱之后就会让你一直缝缝补补,很难有几率能缝缝补补出来。

正如那句话所说:一如入循环深似海,从此offer是路人

 

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 18063 圈中的游戏
  • C/C++语言基础--从C到C++的不同(上)
  • ListBox显示最新数据、左移和右移操作
  • 对中文进行文本分类的常用方法
  • openssl+keepalived安装部署
  • GPT-4论文阅读
  • 9.15 BFS中等 133 Clone Graph review 138 随机链表的复制
  • TikTok商家如何通过真人测评提高流量和销量?
  • Leetcode 第 414 场周赛题解
  • 远程桌面内网穿透是什么?有什么作用?
  • 最新安装vmware地址(官网找半天没找到)
  • Linux: network: IPv6: ESP: UDP checksum error 一例
  • 【devops】devops-git之git分支与标签使用
  • 机器学习实战21-基于XGBoost算法实现糖尿病数据集的分类预测模型及应用
  • redis windows安装包下载路径
  • CAP 一致性协议及应用解析
  • gitlab-ci配置详解(一)
  • HTTP 简介
  • HTTP中的ETag在移动客户端的应用
  • JavaScript 一些 DOM 的知识点
  • java正则表式的使用
  • JS笔记四:作用域、变量(函数)提升
  • React+TypeScript入门
  • Stream流与Lambda表达式(三) 静态工厂类Collectors
  • 等保2.0 | 几维安全发布等保检测、等保加固专版 加速企业等保合规
  • 干货 | 以太坊Mist负责人教你建立无服务器应用
  • 面试题:给你个id,去拿到name,多叉树遍历
  • 我从编程教室毕业
  • 学习使用ExpressJS 4.0中的新Router
  • 原生js练习题---第五课
  • 3月7日云栖精选夜读 | RSA 2019安全大会:企业资产管理成行业新风向标,云上安全占绝对优势 ...
  • NLPIR智能语义技术让大数据挖掘更简单
  • ​MySQL主从复制一致性检测
  • # Redis 入门到精通(八)-- 服务器配置-redis.conf配置与高级数据类型
  • #每日一题合集#牛客JZ23-JZ33
  • $forceUpdate()函数
  • (AngularJS)Angular 控制器之间通信初探
  • (C++17) std算法之执行策略 execution
  • (蓝桥杯每日一题)平方末尾及补充(常用的字符串函数功能)
  • (牛客腾讯思维编程题)编码编码分组打印下标(java 版本+ C版本)
  • (牛客腾讯思维编程题)编码编码分组打印下标题目分析
  • (学习日记)2024.03.12:UCOSIII第十四节:时基列表
  • (一)SvelteKit教程:hello world
  • (一)Thymeleaf用法——Thymeleaf简介
  • (转)ORM
  • *上位机的定义
  • .bat批处理(六):替换字符串中匹配的子串
  • .NET 材料检测系统崩溃分析
  • .net 调用海康SDK以及常见的坑解释
  • .NET 解决重复提交问题
  • .net 写了一个支持重试、熔断和超时策略的 HttpClient 实例池
  • .NET/C# 阻止屏幕关闭,阻止系统进入睡眠状态
  • .net8.0与halcon编程环境构建
  • .net中生成excel后调整宽度
  • .pop ----remove 删除