LeetCode热题100--54.螺旋矩阵--中等

1. 题目

给你一个 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]

2. 题解

java 复制代码
class Solution {
    public List<Integer> spiralOrder(int[][] matrix) {
        List<Integer> result = new ArrayList<>();

        if(matrix == null || matrix.length == 0 || matrix[0].length == 0){
            return result;
        }

        int top = 0, bottom = matrix.length - 1; //上下边界
        int left = 0, right = matrix[0].length - 1; //左右边界

        while(top <= bottom && left <= right){
            //从左到右遍历当前的上边界
            for(int i = left; i <= right; i++){
                result.add(matrix[top][i]);
            }
            top++; //上边界缩小

            //从上到下遍历当前右边界
            for(int i = top; i <= bottom; i++){
                result.add(matrix[i][right]);
            }
            right--; //右边界缩小

            //从右到左遍历当前下边界(需要检查上下边界是否相交)
            if(top <= bottom){
                for(int i = right; i >= left; i--){
                    result.add(matrix[bottom][i]);
                }
                bottom--; //下边界缩小
            }
            //从下往上遍历当前左边界(需要检查左右边界是否相交)
            if(left <= right){
                for(int i = bottom; i>=top; i--){
                    result.add(matrix[i][left]);
                }
                left++; //左边界缩小
            }
        }
        return result;
    }
    
}

3. 解析

  1. List result = new ArrayList<>();

    初始化一个空列表来存储结果,因为我们从左上角开始以螺旋的顺序遍历矩阵。

  2. if(matrix == null || matrix.length == 0 || matrix[0].length == 0) return result;

    如果输入的矩阵为空或者没有元素,则返回已经初始化的空列表。

  3. int top = 0, bottom = matrix.length - 1; int left = 0, right = matrix[0].length - 1;

    定义四个变量来表示矩阵的边界。顶部、底部、左侧和右侧分别对应行号和列号,用于跟踪遍历过程中的位置。

  4. while(top <= bottom && left <= right) { ... }

    这段代码使用循环来以螺旋的顺序访问矩阵,从外到内进行遍历。条件是边界没有相交(即,我们还没有完全遍历完整个矩阵)。

  5. for(int i = left; i <= right; i++) { result.add(matrix[top][i]); } top++;

    从顶部行的左侧到右侧的元素进行循环遍历,并将它们添加到结果列表中。然后,上边界向下移动一步(因为我们已经访问了这一行中的所有元素)。

  6. for(int i = top; i <= bottom; i++) { result.add(matrix[i][right]); } right--;

    从右侧列的顶部到底部的元素进行循环遍历,并将它们添加到结果列表中。然后,有边界向左移动一步(因为我们已经访问了这一列中的所有元素)。

  7. if(top <= bottom) { for(int i = right; i >= left; i--) { result.add(matrix[bottom][i]); } bottom--; }

    如果顶部和底部没有相交,说明我们还没有遍历完最外层的矩阵。这段代码从右侧行的底部到底部的元素进行循环遍历(向后移动)并将它们添加到结果列表中。然后,下边界向上移动一步。

  8. if(left <= right) { for(int i = bottom; i >= top; i--) { result.add(matrix[i][left]); } left++; }

    如果左侧和右侧没有相交,说明我们还没有遍历完最外层的矩阵。这段代码从底部行的左侧到顶部的元素进行循环遍历(向下移动)并将它们添加到结果列表中。然后,左边界向右移动一步。

  9. return result;

    在访问完整个矩阵后,返回最终的结果列表。

相关推荐
玖剹11 小时前
穷举 VS 暴搜 VS 深搜 VS 回溯 VS 剪枝
c语言·c++·算法·深度优先·剪枝·深度优先遍历
李兆龙的博客11 小时前
从一到无穷大 #57:Snowflake的剪枝方案
算法·剪枝
啊我不会诶11 小时前
01BFS学习笔记
笔记·学习·算法
Ch_ty11 小时前
leetcode解题思路分析(一百六十八)1452 - 1458 题
算法·leetcode·哈希算法
哼?~11 小时前
算法学习--离散化
算法
AI科技星12 小时前
引力编程时代:人类文明存续与升维
数据结构·人工智能·经验分享·算法·计算机视觉
Blossom.11817 小时前
移动端部署噩梦终结者:动态稀疏视觉Transformer的量化实战
java·人工智能·python·深度学习·算法·机器学习·transformer
轻微的风格艾丝凡17 小时前
卷积的直观理解
人工智能·深度学习·神经网络·算法·计算机视觉·matlab·cnn
田梓燊20 小时前
红黑树分析 1
算法
晚风吹长发20 小时前
二分查找算法+题目详解
c++·算法·二分查找