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

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

相关推荐
flashlight_hi几秒前
LeetCode 分类刷题:110. 平衡二叉树
javascript·算法·leetcode
式5161 分钟前
线性代数(九)线性相关性、基与维数
线性代数·算法·机器学习
啊阿狸不会拉杆2 分钟前
《数字图像处理》第7章:小波变换和其他图像变换
图像处理·人工智能·python·算法·机器学习·计算机视觉·数字图像处理
炽烈小老头3 分钟前
【 每天学习一点算法 2025/12/17】验证二叉搜索树
学习·算法
用户271995372139 分钟前
基于Label Studio 集成视觉大模型Qwen2-VL和yolo实现自动标注
算法
智者知已应修善业31 分钟前
【删除有序数组中的重复项 II之O(N)算法】2024-1-31
c语言·c++·经验分享·笔记·算法
patrickpdx39 分钟前
leetcode:环形链表
算法·leetcode·链表
资深web全栈开发41 分钟前
LeetCode 3652: 按策略买卖股票的最佳时机
算法·leetcode·职场和发展
Wang ruoxi1 小时前
基于最小二乘法的离散数据拟合
人工智能·算法·机器学习
Xの哲學1 小时前
Linux链路聚合深度解析: 从概念到内核实现
linux·服务器·算法·架构·边缘计算