Leetcode hot100 螺旋矩阵【中等】

和旋转矩阵一样,这个题同样是模拟实现题,就是你脑子里咋想的,用代码还原出来就行。

连直觉都不用靠,过程就是图中画的那样,螺旋着走。

先给代码看看大致吧:

java 复制代码
class Solution {
    public List<Integer> spiralOrder(int[][] matrix) {
        int size=matrix.length*matrix[0].length;
        List<Integer> list = new ArrayList<Integer>();

        //初始化
        int top=1;
        int bottom=matrix.length-1;
        int left=0; 
        int right=matrix[0].length-1;
        
        //初始化
        int x=0;
        int y=-1;  //因为下面的循环里y要先++,所以y从-1开始
        int count=0;

        while(true){
            //先走,再判断
            y++;
            //往右
            while(y<=right) { list.add(matrix[x][y]);count++; y++; }
            if(count==size) break;
            y--;//走出去了一步,处理一下
            right--;//右边界收缩 PS:不用怕边界收缩成负数, 负数了也无所谓,有count控制在合适的时机就退出了

            x++;//先走一步
            //往下
            while(x<=bottom){list.add(matrix[x][y]);count++; x++;}
            if(count==size) break;
            x--;//走出去了一步,处理一下
            bottom--;//下边界收缩

            y--;
            //往左
            while(y>=left){list.add(matrix[x][y]);count++;y--;}
            if(count==size) break;
            y++;//走出去了一步,处理一下
            left++; //左边界收缩

            x--;
            //往上走
            while(x>=top){list.add(matrix[x][y]);count++;x--;}
            if(count==size) break;
            x++; ////走出去了一步,处理一下
            top++; //上边界收缩
            }
            return list;
    }
}

其实就是脑海里演练整个过程,一开始先往右走。往右走就是x不变y一直加加,加到啥时候停下呢?到达右边界 的时候,然后往下走,往下走就是y不变x一直加加,加到啥时候停下呢?到达下边界 的时候,然后往左走,往左走就是x不变y一直减减,啥时候停下呢?到达左边界 的时候。然后往上走,往上走就是y不变x一直减减,啥时候停下呢?到达上边界的时候。然后又开始往右走,这是一个循环。

这么一通分析,你就明白了,难点主要是两点:

**难点1:**一是4个边界的维护

**难点2:**二是退出循环的条件

难点1 :边界处理最难受了。首先,四个边界是取不溢出的最大下标,还是取刚好溢出的下标呢?比如说我一行有4个数,右边界是y=3还是y=4呢?取前者的话用<=去判断边界,取后者的话用<去判断,直觉<=更方便,所以这里用不溢出的最大下标 。再其次还要考虑,4个角上的值属于前一趟走的还是下一趟,我让他属于上一趟,直觉属于上一趟更方便

**难点2:**退出循环的条件。与其乱七八糟的弄边界的判断(比如,right或者left到达边界并且top==left的时候 OR top或者bottom到达边界,我不确定对不对哈),不如直接弄个count计数,天才!

相关推荐
一条大祥脚1 分钟前
Codeforces Round 1099 (Div. 2) 构造|贪心|图论|还原数组
java·算法·图论
Sheldon Chao19 分钟前
Lecture 7 基于策略梯度的算法
人工智能·算法·机器学习
始三角龙24 分钟前
LeetCode hoot 100 -- 缺失的第一个正整数
算法·leetcode·职场和发展
飞Link39 分钟前
深度解析孪生网络(Siamese Network):从原理、技巧到实战应用
算法·数据挖掘·回归
测试狗科研平台1 小时前
洞悉微观电荷流动,VASP计算电荷密度分布
算法·云计算·开源软件
Orz_Sponge_Bob1 小时前
温州市第三届青少年程序设计竞赛(小学组)题解
算法
Noushiki1 小时前
常见的排序算法
算法·排序算法
gumichef2 小时前
二叉树链式结构的实现
算法·链表·二叉树·队列
战南诚2 小时前
力扣 之 198.打家劫舍
python·算法·leetcode
AllData公司负责人2 小时前
亲测丝滑,体验跃迁|AllData通过集成开源项目StreamPark,实时流任务调度更省心!
java·大数据·数据库·人工智能·算法·实时计算·实时开发平台