【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;
    }
相关推荐
智者知已应修善业9 分钟前
【51单片机独立按键控制往复流水灯启停】2023-6-13
c++·经验分享·笔记·算法·51单片机
pen-ai16 分钟前
MAD(Median Absolute Deviation)详解:最稳健的尺度估计方法
人工智能·算法
無限進步D38 分钟前
Java 基础算法训练
java·开发语言·算法·入门
圣保罗的大教堂1 小时前
leetcode 2087. 网格图中机器人回家的最小代价 中等
leetcode
门左有棵树1 小时前
蓝桥杯C++组算法知识点整理(考前急救)
c++·算法·蓝桥杯
历程里程碑1 小时前
二叉树---二叉树的最大深度
大数据·数据结构·算法·elasticsearch·搜索引擎·全文检索·深度优先
自我意识的多元宇宙1 小时前
树与二叉树--树的基本概念
数据结构·算法
吃着火锅x唱着歌1 小时前
LeetCode 678.有效的括号字符串
算法·leetcode·职场和发展
音视频牛哥2 小时前
鸿蒙 NEXT RTSP/RTMP 播放器如何回调 RGB 数据并实现 AI 视觉算法分析
人工智能·算法·harmonyos·鸿蒙rtmp播放器·鸿蒙rtsp播放器·鸿蒙next rtsp播放器·鸿蒙next rtmp播放器
飞Link2 小时前
掌控 Agent 的时空法则:LangGraph Checkpoint (检查点) 机制深度实战
开发语言·python·算法