59. Spiral Matrix II

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

Example 1:

复制代码
Input: n = 3
Output: [[1,2,3],[8,9,4],[7,6,5]]

Example 2:

复制代码
Input: n = 1
Output: [[1]]

Constraints:

  • 1 <= n <= 20

    class Solution {
    public:
    vector<vector<int>> generateMatrix(int n) {
    vector<vector<int>>nums(n,vector<int>(n,0));
    int StartX=0,StartY=0;
    int count=1;
    int offset=1;
    int loop=n/2;
    while(loop--){
    int i,j;
    for(j=StartY;j<n-offset;j++){
    nums[StartX][j]=count++;
    }
    for(i=StartX;i<n-offset;i++){
    nums[i][j]=count++;
    }
    for(;j>StartY;j--){
    nums[i][j]=count++;
    }
    for(;i>StartX;i--){
    nums[i][j]=count++;
    }
    StartX++;
    StartY++;
    offset++;
    }
    if(n%2==1){
    nums[n/2][n/2]=count;
    }
    return nums;
    }
    };

注意:

1.offset的初始值,其实就是因为数组的行和列都是从0开始的

2.注意边界条件,数组别越界了

3.每旋转一圈StartX、StartY和offset都要+1

4.总体思路是用到了左闭右开的原则,这点参考二分查找,每行每列的最后一个元素都是交给下一个循环的时候做

这道题的算法很简单,就是需要处理的边界条件有点绕,很容易没注意到就错了,小心数组的越界

相关推荐
.YM.Z33 分钟前
【数据结构】:排序(一)
数据结构·算法·排序算法
Chat_zhanggong34536 分钟前
K4A8G165WC-BITD产品推荐
人工智能·嵌入式硬件·算法
百***48071 小时前
【Golang】slice切片
开发语言·算法·golang
墨染点香1 小时前
LeetCode 刷题【172. 阶乘后的零】
算法·leetcode·职场和发展
做怪小疯子1 小时前
LeetCode 热题 100——链表——反转链表
算法·leetcode·链表
做怪小疯子3 小时前
LeetCode 热题 100——矩阵——旋转图像
算法·leetcode·矩阵
努力学习的小廉3 小时前
我爱学算法之—— BFS之最短路径问题
算法·宽度优先
高山上有一只小老虎4 小时前
构造A+B
java·算法
木头左4 小时前
缺失值插补策略比较线性回归vs.相邻填充在LSTM输入层的性能差异分析
算法·线性回归·lstm
sin_hielo4 小时前
leetcode 2435
数据结构·算法·leetcode