LeetCode59:螺旋矩阵Ⅱ

题目描述

给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。

示例 1:

输入:n = 3

输出:[[1,2,3],[8,9,4],[7,6,5]]

代码

cpp 复制代码
class Solution {
public:
    vector<vector<int>> generateMatrix(int n) {
        vector<vector<int>> matrix(n, vector<int>(n)); //使用vector定义一个二维数组

        int startX = 0, startY = 0; //定义每循环一圈的起始位置
        int offset = 1;///需要控制每一条边遍历的长度,每次循环右边界收缩一位
        int loop = n / 2;//圈循环的次数,如果为奇数,就把最中间的位置直接填充
        int count = 1; //用来给矩阵中每一个空格赋值
        int i, j;
        while (loop--) {
            
            //下面开始的四个for就是模拟了一圈

            //模拟 填充上行 从左到右(左闭右开)
            for (j = startY; j < n - offset; j++) {  
                matrix[startX][j] = count++;
            }
            //模拟 填充右列 从上到下(左闭右开)
            for (i = startX; i < n - offset; i++) {
                matrix[i][j] = count++;
            }

            //模拟 填充下行 从右到做(左闭右开)
            for (; j > startY; j--) {
                matrix[i][j] = count++;
            }

            //模拟 填充左列 从下到上(左闭右开)
            for (; i > startX; i--) {
                matrix[i][j] = count++;
            }

            //第二圈开始的时候,起始位置要各自加1, 
            // 例如:第一圈起始位置是(0, 0),第二圈起始位置是(1, 1)
            startX++;
            startY++;

             offset 控制每一圈里每一条边遍历的长度
            offset++;
        }
        
        // 如果n为奇数的话,需要单独给矩阵最中间的位置赋值
        if (n % 2 != 0)
            matrix[n / 2][n / 2] = count;
        return matrix;
    }
};
相关推荐
一匹电信狗5 小时前
【LeetCode_547_990】并查集的应用——省份数量 + 等式方程的可满足性
c++·算法·leetcode·职场和发展·stl
鱼跃鹰飞6 小时前
Leetcode会员尊享100题:270.最接近的二叉树值
数据结构·算法·leetcode
梵刹古音7 小时前
【C语言】 函数基础与定义
c语言·开发语言·算法
筵陌7 小时前
算法:模拟
算法
We་ct8 小时前
LeetCode 205. 同构字符串:解题思路+代码优化全解析
前端·算法·leetcode·typescript
renhongxia18 小时前
AI算法实战:逻辑回归在风控场景中的应用
人工智能·深度学习·算法·机器学习·信息可视化·语言模型·逻辑回归
CoderCodingNo8 小时前
【GESP】C++四级/五级练习题 luogu-P1223 排队接水
开发语言·c++·算法
民乐团扒谱机8 小时前
【AI笔记】精密光时频传递技术核心内容总结
人工智能·算法·光学频率梳
CoderCodingNo8 小时前
【GESP】C++五级/四级练习题 luogu-P1413 坚果保龄球
开发语言·c++·算法
2301_822366359 小时前
C++中的命令模式变体
开发语言·c++·算法