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 == matrix[i].length

1 <= m, n <= 10

-100 <= matrix[i][j] <= 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. 旋转图像

相关推荐
汤姆yu1 小时前
基于springboot的智能民宿预定与游玩系统
java·spring boot·后端
黎雁·泠崖1 小时前
Java常用类核心精讲 · 七篇精华总结
java·开发语言
测绘工程师1 小时前
【排序算法】冒泡排序
数据结构·算法·排序算法
m0_672703311 小时前
上机练习第28天
算法
niuniudengdeng1 小时前
一种基于HFF4材料的自消亡类脑芯片架构构想:把神经网络的训练变成物理化学过程
人工智能·神经网络·算法
逆境不可逃1 小时前
【从零入门23种设计模式01】创建型之工厂模式(简单工厂+工厂方法+抽象工厂)
java·spring·设计模式·简单工厂模式·工厂方法模式·抽象工厂模式·工厂模式
载数而行5201 小时前
算法系列1之最小生成树
c语言·数据结构·c++·算法·贪心算法
额,不知道写啥。1 小时前
HAO的DP
c++·算法·深度优先·动态规划
重生之后端学习2 小时前
208. 实现 Trie (前缀树)
java·开发语言·数据结构·算法·职场和发展·深度优先
Sayuanni%32 小时前
初阶_多线程2(线程安全)
java