leetcode【数组—中等】59.螺旋矩阵

简介: leetcode【数组—中等】59.螺旋矩阵

题目


题目来源leetcode


leetcode地址:59. 螺旋矩阵 II,难度:中等。


题目描述(摘自leetcode):


给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。
示例 1:
输入:n = 3
输出:[[1,2,3],[8,9,4],[7,6,5]]
示例 2:
输入:n = 1
输出:[[1]]
提示:
1 <= n <= 20


本地调试代码:


class Solution {
    //业务代码
    public int[][] generateMatrix(int n) {
        ...
    }
    public static void main(String[] args) {
        int n = 4;//设置边长度
        printMatrix(n);
    }
    public static void printMatrix(int n){
        Solution solution = new Solution();
        int m = n * n;
        int numLen = 0;
        while (m > 0) {
            m = m / 10;
            numLen++;
        }
        numLen += 2;//每个数字之间空两个
        int[][] ints = solution.generateMatrix(n);
        for (int i = 0; i < ints.length; i++) {
            for (int j = 0; j < ints[i].length; j++) {
                System.out.printf("%-" + numLen + "d", ints[i][j]); //numLen表示长度,-表示左对齐。例如:%-4d => 宽度为4,左对齐
            }
            System.out.println();
        }
    }
}




题解


这是一道逻辑题,花费了我一个多小时解出来,关键就是需要你找到其中的规律!


思路:


刚开始实在没有头绪,就去看了大佬的一个题解思路,看到下面这张图之后就开始撸代码了,我觉得最核心的就是下面这个图,其他主要就是你要找一些规律,例如有边长n对应有多少圈;在哪一圈上下左右每次需要填充的数量;最里边填充一个数字的情况…



图片取自:代码随想录—螺旋矩阵

代码:


public int[][] generateMatrix(int n) {
    int[][] matrixArr = new int[n][n];
    if (n == 1) {
        matrixArr[0][0] = 1;
        return matrixArr;
    }
    //填充的数
    int num = 1;
    //圈数
    int outCircleNums = n % 2 == 1 ? n / 2 + 1 : n / 2;
    //每层(上下左右)要填充的对应数量。例如上图3*3,上下左右方向都要填充2个
    int curTire = 0;
    //圈数遍历
    for (int i = 0; i < outCircleNums; i++) {
        //求每层(上下左右)要填充的对应数量
        if (i == 0) {
            curTire = n - 1;//最外圈只要-1即可
        } else {
            curTire = curTire - 2;//里面的每一圈都要-2
        }
        //最内圈只有一个数的情况
        if (i == outCircleNums - 1 && n % 2 == 1) {
            matrixArr[i][i] = num;
            break;
        }
        //绘制正方形上层
        for (int j = i; j < i + curTire; j++) {
            matrixArr[i][j] = num++;
        }
        //绘制正方形右边
        for (int j = i; j < i + curTire; j++) {
            matrixArr[j][curTire + i] = num++;
        }
        //绘制正方形下边
        for (int j = i + curTire; j > i; j--) {
            matrixArr[curTire + i][j] = num++;
        }
        //绘制正方形左边
        for (int j = i + curTire; j > i; j--) {
            matrixArr[j][i] = num++;
        }
    }
    return matrixArr;
}




本地调试效果图:





相关文章
|
3月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
49 0
|
5月前
|
算法
LeetCode第53题最大子数组和
LeetCode第53题"最大子数组和"的解题方法,利用动态规划思想,通过一次遍历数组,维护到当前元素为止的最大子数组和,有效避免了复杂度更高的暴力解法。
LeetCode第53题最大子数组和
|
3月前
|
C++
Leetcode第54题(螺旋矩阵)
这篇文章介绍了LeetCode第54题“螺旋矩阵”的解题思路和C++的实现代码,该题目要求按照顺时针螺旋顺序返回给定矩阵中的所有元素。
24 1
Leetcode第54题(螺旋矩阵)
|
3月前
【LeetCode-每日一题】 删除排序数组中的重复项
【LeetCode-每日一题】 删除排序数组中的重复项
27 4
|
3月前
|
索引
Leetcode第三十三题(搜索旋转排序数组)
这篇文章介绍了解决LeetCode第33题“搜索旋转排序数组”的方法,该问题要求在旋转过的升序数组中找到给定目标值的索引,如果存在则返回索引,否则返回-1,文章提供了一个时间复杂度为O(logn)的二分搜索算法实现。
26 0
Leetcode第三十三题(搜索旋转排序数组)
|
3月前
|
算法 C++
Leetcode第53题(最大子数组和)
这篇文章介绍了LeetCode第53题“最大子数组和”的动态规划解法,提供了详细的状态转移方程和C++代码实现,并讨论了其他算法如贪心、分治、改进动态规划和分块累计法。
79 0
|
3月前
|
C++
【LeetCode 12】349.两个数组的交集
【LeetCode 12】349.两个数组的交集
25 0
|
3月前
【LeetCode 05】螺旋矩阵II总结
【LeetCode 05】螺旋矩阵II总结
26 0
|
5月前
|
算法
LeetCode第81题搜索旋转排序数组 II
文章讲解了LeetCode第81题"搜索旋转排序数组 II"的解法,通过二分查找算法并加入去重逻辑来解决在旋转且含有重复元素的数组中搜索特定值的问题。
LeetCode第81题搜索旋转排序数组 II
|
5月前
|
算法
LeetCode第59题螺旋矩阵 II
LeetCode第59题"螺旋矩阵 II"的解题方法,通过模拟螺旋填充过程,一圈一圈从外到内按顺序填充数字,直到完成整个矩阵的构建。
LeetCode第59题螺旋矩阵 II