欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

力扣 59.螺旋矩阵 || - 输入:n = 1 Output:[[1]] 提示

最编程 2024-10-07 10:32:24
...
  • 1 <= n <= 20
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;
    }
}