leetcode54. 螺旋矩阵(java)

螺旋矩阵

题目描述

难度 - 中等
原题链接 - leecode 54 螺旋矩阵
给你一个 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 == matrixi.length

1 <= m, n <= 10

-100 <= matrixij <= 100

解题 收缩法

解题的核心思路是按照右、下、左、上的顺序遍历数组,并使用四个变量圈定未遍历元素的边界:
随着螺旋遍历,相应的边界会收缩,直到螺旋遍历完整个数组:
把上面过程翻译成代码:

java 复制代码
class Solution {
   List<Integer> spiralOrder(int[][] matrix) {
       int upper_bound = 0;
       int lower_bound = matrix.length - 1;
       int left_bound = 0;
       int right_bound = matrix[0].length - 1;
       List<Integer>ans = new LinkedList<>();
       while(ans.size() < matrix.length * matrix[0].length){
           //从左往右
           if(upper_bound <= lower_bound){
               for(int i = left_bound;i <= right_bound;i++){
                   ans.add(matrix[upper_bound][i]);
               }
               //上边界下移
               upper_bound++;
           }
           //从上到下
           if(left_bound <= right_bound){
               for(int i = upper_bound;i <= lower_bound;i++){
                   ans.add(matrix[i][right_bound]);
               }
               //右边界左移
               right_bound--;
           }

           //从右向左
           if(upper_bound <= lower_bound){
               for(int i = right_bound;i >= left_bound;i--){
                   ans.add(matrix[lower_bound][i]);
               }
               lower_bound--;
           }
           //从下向上
           if(left_bound <= right_bound){
               for(int i = lower_bound;i >= upper_bound;i--){
                   ans.add(matrix[i][left_bound]);
               }
               left_bound++;
           }
       }
       return ans;
   }

}

上期经典算法

leetcode48. 旋转图像

相关推荐
aini_lovee5 小时前
MATLAB 图像修复 — 偏微分方程方法
算法
Cthy_hy5 小时前
Python算法竞赛:排列组合核心用法
开发语言·python·算法
大圣编程6 小时前
面向对象深度理解
java·开发语言·算法
爱喝水的鱼丶6 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第四篇:SAP 报表异常处理机制:数据校验与消息提示规范落地
开发语言·数据库·学习·算法·sap·abap
影寂ldy6 小时前
C# const 常量 / readonly 只读 / static readonly
java·开发语言·c#
摇滚侠6 小时前
Maven 入门+高深 体系外 jar 包导入 172
java·maven·jar
做个文艺程序员6 小时前
第02篇:K8s 存储与配置管理:ConfigMap、Secret、PV/PVC 实战——Java SaaS 多租户配置最佳实践
java·容器·kubernetes
爱吃牛肉的大老虎6 小时前
Spring中用到的设计模式
java·spring·设计模式
Refrain_zc6 小时前
Android TV 语音消息实战:遥控器 PCM 录音失真修复与扬声器强制播放方案
java
Stick_ZYZ6 小时前
从“能调用工具”到“能稳定执行任务”:Agent 工程化的下一步
java·人工智能·后端·spring·ai