力扣54题——螺旋矩阵

题目:

给你一个 mn 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。

实现代码:

java 复制代码
class Solution {
    public List<Integer> spiralOrder(int[][] matrix) {
        int m=matrix.length;
        int n = matrix[0].length;
        List<Integer> res=new ArrayList<>();    //list接口实现arrayList这个数组
        int l=0,r=n-1,t=0,b=m-1;
        while(true){
            for(int i=l;i<=r;i++){
                res.add(matrix[t][i]);
            }
            if(++t>b){
                break;
            }
            for(int i=t;i<=b;i++){
                res.add(matrix[i][r]);
            }
            if(l>--r){
                break;
            }
            for(int i=r;i>=l;i--){
                res.add(matrix[b][i]);
            }
            if(t>--b){
                break;
            }
            for(int i=b;i>=t;i--){
                res.add(matrix[i][l]);
            }
            if(++l>r){
                break;
            }
        }
        return res;
    }
}

思路讲解:

这边是学习了Krahets大佬的思路,感兴趣的小伙伴可以去力扣找这个题去看看。

这道题一开始我也像力扣59题一样写了count以及target,但是在执行的时候发现循环只执行了第一圈,仔细思考后发现没有注意到while语句,应该是没有退出条件循环被写死了,所以力扣测试环境应该也怕死循环所以就在第一圈结束给我停止了,所以大家可以看到实现代码中while里的条件是true,只要是后面能有退出条件就能解决这个问题,而这题其他思路和59题没有太大差别,大家可以对比两道题目多去思考,动手去实现一下。这里再放一下链接,大家有兴趣多看看:https://blog.csdn.net/suibiansa_/article/details/145157858

共勉!

相关推荐
Raink老师7 小时前
【AI面试临阵磨枪-62】设计基于 RAG 的内部知识库问答平台(多租户、权限、文件上传、实时更新)
人工智能·面试·职场和发展
cd_949217218 小时前
2026年扫描电子显微镜选型指南:易姆科特的核心优势与产品矩阵解析
人工智能·线性代数·矩阵
smj2302_796826528 小时前
解决leetcode第3943题递增后的数对数量
数据结构·python·算法·leetcode
oo哦哦9 小时前
星链引擎矩阵系统深度解析:AI驱动下的全域智能营销SaaS新范式
大数据·人工智能·矩阵
炽烈小老头9 小时前
【每天学习一点算法 2026/05/25】矩阵中的最长递增路径
学习·算法·矩阵
oo哦哦9 小时前
轻量化内容中台如何破解企业矩阵运营困局?以星链引擎为例的技术解析
大数据·人工智能·矩阵
我爱cope9 小时前
【Agent智能体6 | 智能体AI评估】
人工智能·职场和发展
oo哦哦10 小时前
企业级矩阵管理中台:从“人海战术“到“AI智能增长“的架构演进与实践解析
人工智能·矩阵·架构·轻量化中台
叁散10 小时前
实验报告:5G 仿真环境与基本链路模拟
算法
从负无穷开始的三次元代码生活10 小时前
算法零碎灵感点分享
算法