【LeetCode-中等题】54. 螺旋矩阵

文章目录

题目

方法一:按层模拟

思路就是定义四个指针边界,按顺序扫完一遍,再缩小区域再扫描

java 复制代码
 public List<Integer> spiralOrder(int[][] matrix) {
        List<Integer> order = new ArrayList<Integer>(); 
        int matrixlength = matrix.length;
        int matrixNumlength = matrix[0].length;
        //判空条件
        if(matrix==null ||  matrixlength == 0 || matrixNumlength == 0) return order;
        //定义四个指针边界
        int top = 0;//行边界
        int bot = matrixlength-1;
        int left = 0;//列边界
        int right = matrixNumlength-1;
        while(left <= right && top <= bot){
        // 首先循环最外层  顺序依次为右下左上
           // (left)                   (right)
        // (top)1,      2,      3,       4 (top)
        //      5,      6,      7,       8
        // (bot)9,      10,     11,     12(bot)
           // (left)                    (right)

        //右 -->  左  最上层
        for(int i = left ;i <= right;i++){
            order.add(matrix[top][i]);
        }

         //上 -->  下  最右层
        for(int i = top+1 ;i <= bot;i++){
            order.add(matrix[i][right]);
        }
    if(left!=right  && bot!=top){//  如果right和left重合了  说明上往下扫描了一遍,就不需要再从下往上重复扫一遍了
                                //  如果 bot 和 top 重合了  说明左往右扫描了一遍,就不需要再从右往左重复扫一遍了
         //左 -->  右  最下层
        for(int i = right-1 ;i >= left;i--){
            order.add(matrix[bot][i]);
        }
  
          //下 -->  上  最左层
        for(int i = bot-1 ;i >top;i--){
            order.add(matrix[i][left]);
        }
  }    
        //往里缩一圈
        left  ++;
        right --;
        top ++;
        bot --;
        }
        return order;
    }
相关推荐
周杰伦_Jay18 小时前
【 RocketMQ 全解析】分布式消息队列的架构、消息转发与快速实践、事务消息
分布式·算法·架构·rocketmq·1024程序员节
sprintzer19 小时前
10.16-10.25力扣计数刷题
算法·leetcode
王哈哈^_^19 小时前
【数据集】【YOLO】【目标检测】建筑垃圾数据集 4256 张,YOLO建筑垃圾识别算法实战训推教程。
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·数据集
CoovallyAIHub19 小时前
不看异常,怎么学会识别异常?用“异常”指导异常检测!——NAGL方法解析(附代码地址)
深度学习·算法·计算机视觉
共享家952720 小时前
数据结构-并查集
数据结构·c++·算法
IT古董20 小时前
【第五章:计算机视觉-项目实战之推荐/广告系统】2.粗排算法-(2)理解粗排模型之离线部分:双塔模型结构精讲及实现
人工智能·算法·计算机视觉
茉莉玫瑰花茶20 小时前
贪心 - 后篇
算法
m0_7482336420 小时前
【C++篇】C++11入门:踏入C++新世界的大门
java·c++·算法
lxmyzzs20 小时前
【图像算法 - 31】基于深度学习的太阳能板缺陷检测系统:YOLOv12 + UI界面 + 数据集实现
人工智能·深度学习·算法·yolo·缺陷检测
lxmyzzs20 小时前
【图像算法 - 32】基于深度学习的风力发电设备缺陷检测系统:YOLOv12 + UI界面 + 数据集实现
深度学习·算法·yolo·计算机视觉