59. 螺旋矩阵 II

题目描述

给你一个正整数 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

解答

cpp 复制代码
class Solution {
public:
    vector<vector<int>> generateMatrix(int n) {
        // 生成顺序:每一轮右下左上
        vector<vector<int>> res(n, vector<int>(n, 0));
        int left = 0, right = n - 1, up = 0, down = n - 1; // 四方向边界
        int  i = 0, j = 0; // 起始位置
        for(int i = 1; i <= n*n;)
        {
            // 右
            for(int j = left; j <= right; ++j)
            {
                res[up][j] = i++;
            }
            up = up + 1; // 上边界下移一个单位
            // 下
            for(int j = up; j <= down; ++j)
            {
                res[j][right] = i++;
            }
            right = right - 1; // 右边界左移一个单位
            // 左
            for(int j = right; j >= left; --j)
            {
                res[down][j] = i++;
            }
            down = down - 1;
            // 下
            for(int j = down; j >= up; --j)
            {
                res[j][left] = i++;
            }
            left = left + 1;
        }
        return res;
    }
};
相关推荐
被开发耽误的大厨12 分钟前
1、==、equals、hashCode底层原理?重写场景?
算法·哈希算法
WolfGang00732135 分钟前
代码随想录算法训练营 Day38 | 动态规划 part11
算法·动态规划
松☆2 小时前
C++ 算法竞赛题解:P13569 [CCPC 2024 重庆站] osu!mania —— 浮点数精度陷阱与 `eps` 的深度解析
开发语言·c++·算法
jr-create(•̀⌄•́)2 小时前
正则化和优化算法区别
pytorch·深度学习·神经网络·算法
li星野3 小时前
刷题:数组
数据结构·算法
tankeven4 小时前
HJ182 画展布置
c++·算法
CS_Zero5 小时前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机
杰梵5 小时前
聚酯切片DSC热分析应用报告
人工智能·算法
@BangBang6 小时前
leetcode (4): 连通域/岛屿问题
算法·leetcode·深度优先
Ulyanov6 小时前
像素迷宫:路径规划算法的可视化与实战
大数据·开发语言·python·算法