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;
    }
};
相关推荐
董董灿是个攻城狮2 小时前
5分钟搞懂什么是窗口注意力?
算法
Dann Hiroaki2 小时前
笔记分享: 哈尔滨工业大学CS31002编译原理——02. 语法分析
笔记·算法
qqxhb4 小时前
零基础数据结构与算法——第四章:基础算法-排序(上)
java·数据结构·算法·冒泡·插入·选择
FirstFrost --sy5 小时前
数据结构之二叉树
c语言·数据结构·c++·算法·链表·深度优先·广度优先
森焱森6 小时前
垂起固定翼无人机介绍
c语言·单片机·算法·架构·无人机
搂鱼1145146 小时前
(倍增)洛谷 P1613 跑路/P4155 国旗计划
算法
Yingye Zhu(HPXXZYY)6 小时前
Codeforces 2021 C Those Who Are With Us
数据结构·c++·算法
无聊的小坏坏7 小时前
三种方法详解最长回文子串问题
c++·算法·回文串
长路 ㅤ   7 小时前
Java后端技术博客汇总文档
分布式·算法·技术分享·编程学习·java后端
秋说8 小时前
【PTA数据结构 | C语言版】两枚硬币
c语言·数据结构·算法