[LeetCode]day6 59.螺旋矩阵2

59. 螺旋矩阵 II - 力扣(LeetCode)

题目描述

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

示例 1:

复制代码
输入:n = 3
输出:[[1,2,3],[8,9,4],[7,6,5]]

示例 2:

复制代码
输入:n = 1
输出:[[1]]

题解

这题处理每条边时要遵循相同的一个原则 类似于集合中的左闭右开 左闭右闭

在做这道题时最好是留这个边的最后一个元素给下一条边处理(如图,来自代码随想录)

cpp 复制代码
class Solution {
public:
    vector<vector<int>> generateMatrix(int n) {
        vector<vector<int>>re (n,vector<int>(n));
        int loop=n/2; //一共有n/2圈
        int startX=0,startY=0,offset=1,count=1,i,j;
        while(loop--){ 
         //依次处理四条边
           for(j=startY;j<n-offset;j++){
              re[startX][j]=count++;
           }
           for(i=startX;i<n-offset;i++){
            re[i][j]=count++;
           }
           for(;j>startY;j--){
            re[i][j]=count++;
           }
           for(;i>startX;i--){
            re[i][startY]=count++;
           }
          
           startX++;
           startY++;
           offset++;
        }
      //如果是奇数的话还要额外处理最中间那个元素
        if(n%2==1){
            re[n/2][n/2]=n*n;
        }
        return re;
    }
};
相关推荐
森焱森26 分钟前
APM与ChibiOS系统
c语言·单片机·算法·架构·无人机
★Orange★36 分钟前
Linux Kernel kfifo 实现和巧妙设计
linux·运维·算法
尘世闲鱼40 分钟前
解数独(C++版本)
开发语言·c++·算法·解数独
qqxhb1 小时前
零基础数据结构与算法——第四章:基础算法-排序(中)
数据结构·算法·排序算法·归并·快排·堆排
张晓~183399481211 小时前
数字人源码部署流程分享--- PC+小程序融合方案
javascript·小程序·矩阵·aigc·文心一言·html5
Y1nhl2 小时前
力扣_链表_python版本
开发语言·python·算法·leetcode·链表·职场和发展
qq_401700412 小时前
C语言中位运算以及获取低8位和高8位、高低位合并
c语言·开发语言·算法
CoovallyAIHub2 小时前
YOLO模型优化全攻略:从“准”到“快”,全靠这些招!
深度学习·算法·计算机视觉
闻缺陷则喜何志丹3 小时前
【BFS】 P10864 [HBCPC2024] Genshin Impact Startup Forbidden II|普及+
c++·算法·宽度优先·洛谷
MicroTech20253 小时前
微算法科技(NASDAQ: MLGO)探索Grover量子搜索算法,利用量子叠加和干涉原理,实现在无序数据库中快速定位目标信息的效果。
数据库·科技·算法