力扣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

共勉!

相关推荐
米粒12 小时前
力扣算法刷题 Day 27
算法·leetcode·职场和发展
Fuxiao___3 小时前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#
Mr_Xuhhh4 小时前
LeetCode hot 100(C++版本)(上)
c++·leetcode·哈希算法
漫随流水4 小时前
c++编程:反转字符串(leetcode344)
数据结构·c++·算法
穿条秋裤到处跑5 小时前
每日一道leetcode(2026.03.31):字典序最小的生成字符串
算法·leetcode
CoovallyAIHub7 小时前
VisionClaw:智能眼镜 + Gemini + Agent,看一眼就能帮你搜、帮你发、帮你做
算法·架构·github
Titan20247 小时前
map和set的封装学习笔记
数据结构·c++
CoovallyAIHub7 小时前
低空安全刚需!西工大UAV-DETR反无人机小目标检测,参数减少40%,mAP50:95提升6.6个百分点
算法·架构·github
CoovallyAIHub7 小时前
IEEE Sensors | 湖南大学提出KGP-YOLO:先定位风电叶片再检测缺陷,三数据集mAP均超87%
算法
Yupureki8 小时前
《算法竞赛从入门到国奖》算法基础:动态规划-路径dp
数据结构·c++·算法·动态规划