力扣59.螺旋矩阵||

题目链接:59. 螺旋矩阵 II - 力扣(LeetCode)

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

示例 1:

复制代码
输入:n = 3
输出:[[1,2,3],[8,9,4],[7,6,5]]

示例 2:

复制代码
输入:n = 1
输出:[[1]]

提示:

  • 1 <= n <= 20
java 复制代码
class Solution {
    public int[][] generateMatrix(int n) {
        int[][] nums=new int[n][n];
        int startX=0,startY=0; //每一圈的起始点
        int offset=1;
        int circle=1; //当前圈数
        int i=0,j=0;
        int count=1; //要填的数字

        while(circle<=n/2){ //一共n/2圈
        //顶部
        for(j=startY;j<n-offset;j++){
            nums[startX][j]=count++;
        }//循环结束时j=n-offset

        //右列
        for(i=startX;i<n-offset;i++){
            nums[i][j]=count++;//j=n-offset
        }//循环结束时i=n-offset

        //底部 
        //此时j=n-offset,不需要初始化,且i=n-offset
        for(;j>startY;j--){
            nums[i][j]=count++;//i=n-offset
        }//循环结束时j=startY=0

        //左列
        for(;i>startX;i--){
            nums[i][j]=count++;//j=startY=0
        }//循环结束时i=startX=0,j=startY=0

        startX++;
        startY++;
        offset++;
        circle++;

        }

        //n为奇数时,需要单独处理中心点
        if(n%2!=0){
            nums[n/2][n/2]=n*n;
            //nums[startX][startY] = count;
        }

        return nums;
    }
}
相关推荐
烟花落o6 分钟前
【数据结构系列01】时间复杂度和空间复杂度:消失的数字
数据结构·算法·leetcode·刷题
㓗冽7 分钟前
阵列(二维数组)-基础题79th + 饲料调配(二维数组)-基础题80th + 求小数位数个数(字符串)-基础题81th
数据结构·c++·算法
努力学算法的蒟蒻10 分钟前
day86(2.15)——leetcode面试经典150
数据结构·leetcode·面试
识君啊16 分钟前
Java双指针 - 附LeetCode 经典题解
java·算法·leetcode·java基础·双指针
_F_y18 分钟前
子序列系列动态规划
算法·动态规划
田里的水稻21 分钟前
FA_规划和控制(PC)-A*(规划01)
人工智能·算法·数学建模·机器人·自动驾驶
twilight_46921 分钟前
机器学习与模式识别——Logistic算法
人工智能·算法·机器学习
ArturiaZ30 分钟前
【day28】
开发语言·c++·算法
致Great31 分钟前
使用 GRPO 算法训练多智能体系统:实现可靠的长期任务规划与执行
人工智能·算法·agent·智能体
AI科技星1 小时前
光速为何是宇宙的终极速度极限?
人工智能·线性代数·算法·矩阵·数据挖掘