【Leetcode·中等·数组】59. 螺旋矩阵 II(spiral matrix ii)

题目描述

英文版描述

Given a positive integer n, generate an n x n matrix filled with elements from 1 to n(2) in spiral order.

Example 1:

Input: n = 3

Output: [[1,2,3],[8,9,4],[7,6,5]]

提示:

  • 1 <= n <= 20

英文版地址

https://leetcode.com/problems/spiral-matrix-ii/https://leetcode.com/problems/spiral-matrix-ii/

中文版描述

给你一个正整数 n ,生成一个包含 1n^2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix

示例 1:

**输入:**n = 3

输出:[[1,2,3],[8,9,4],[7,6,5]]

提示:

  • 1 <= n <= 20

中文版地址

https://leetcode.cn/problems/spiral-matrix-ii/https://leetcode.cn/problems/spiral-matrix-ii/

分析

这道题其实并不难(别打我= =,第一次做的时候我也没转出来),其实我们一开始转不出来的原因就在于没有把"上右下左"看成1个整体,当你把"上右下左"即转 1 圈看正一个整体,只有这4个都完成了才是完成1次循环,这样,其实就不难了,你要做的就是判断要转几圈(几圈就是几次循环♻️),以及每一圈的"上右下左"分别该如何处理(循环内部逻辑)

解题过程

  1. 判断需要转几圈

  2. 每圈分别处理"上右下左"(因为按这个顺序值只需要每次+1 即可)

  3. 处理最后一个数(如果 n 是奇数的话)

完整答案

java 复制代码
class Solution {
    public int[][] generateMatrix(int n) {
        int startRow=0;
        int endRow=n-1;  //2
        int startCol=0;
        int endCol=n-1;  // 2
        int value=1;
        int[][] result=new int[n][n];
        int times=n/2;

        while(times>0){
            // 关键点在于将上右下左看成1个整体,这四个都完成了才是完成1次循环
            // up
            for(int i=startCol;i<endCol;i++){
                result[startRow][i]=value;
                value++;
            }
            // right
            for(int j=startRow;j<endRow;j++){
                result[j][endCol]=value;
                value++;
            }
            // down
            for(int k=endCol;k>startCol;k--){
                result[endRow][k]=value;
                value++;
            }
            // left
            for(int g=endCol;g>startCol;g--){
                result[g][startRow]=value;
                value++;
            }
            startRow++;
            endRow--;
            startCol++;
            endCol--;
            times--;
        }
        if(n%2!=0){
            result[n/2][n/2]=n*n;
        }
        return result;
    }
}

执行结果

复杂度

  • 时间复杂度: O(n^2)

  • 空间复杂度: O(1)

恭喜你又做完了一道题🎉🎉🎉~~~

相关推荐
FakeOccupational1 天前
【数学 密码学】量子通信:光的偏振&极化的量子不确定性特性 + 量子密钥分发 BB84算法步骤
算法·密码学
ZhengEnCi1 天前
S10-蓝桥杯 17822 乐乐的积木塔
算法
贾斯汀玛尔斯1 天前
每天学一个算法--拓扑排序(Topological Sort)
算法·深度优先
大龄程序员狗哥1 天前
第25篇:Q-Learning算法解析——强化学习中的经典“价值”学习(原理解析)
人工智能·学习·算法
exp_add31 天前
质数相关知识
算法
小辉同志1 天前
215. 数组中的第K个最大元素
数据结构·算法·leetcode··快速选择
小O的算法实验室1 天前
2025年IEEE TITS,基于矩阵的进化计算+面向无线传感器网络数据收集无人机路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
OidEncoder1 天前
编码器分辨率与机械精度的关系
人工智能·算法·机器人·自动化
memcpy01 天前
LeetCode 2615. 等值距离和【相同元素分组+前缀和;考虑距离和的增量】中等
算法·leetcode·职场和发展
炽烈小老头1 天前
【 每天学习一点算法 2026/04/22】四数相加 II
学习·算法