力扣59-螺旋矩阵

螺旋矩阵

题目链接

c++ 复制代码
class Solution {
public:
    vector<vector<int>> generateMatrix(int n) {
        vector<vector<int>>res(n, vector<int>(n, 0));
        int dx[4] = {0, 1, 0, -1}, dy[4] = {1, 0, -1, 0};  //方向偏移数组
        int x = 0, y = 0;  //当前位置
        for(int i = 1, d = 0; i <= n*n; i++)
        {
            res[x][y] = i; 
            int a = x + dx[d], b = y + dy[d]; 
            if(a <0 || a == n || b < 0 || b == n || res[a][b]){  //出界或者该位置已经被走过
                d = (d + 1) % 4;   //更改方向
                a = x + dx[d], b = y + dy[d];  //下一个要走的位置
            }
            x = a, y = b;    
        }
        return res;
    }
};
相关推荐
谙弆悕博士4 小时前
快速学C语言——第19章:C语言常用开发库
c语言·开发语言·算法·业界资讯·常用函数
光影少年4 小时前
前端算法题
前端·javascript·算法
南宫萧幕4 小时前
基于 Simulink 与 Python 联合仿真的 eVTOL 强化学习全链路实战
开发语言·人工智能·python·算法·机器学习·控制
电魂泡哥4 小时前
CMS垃圾回收
java·jvm·算法
hkj88085 小时前
CRC-512算法输出64字节
算法
@我漫长的孤独流浪5 小时前
计算机系统核心概念与性能优化全解析
算法·计算机外设
如竟没有火炬5 小时前
接雨水22
数据结构·python·算法·leetcode·散列表
ʚ希希ɞ ྀ5 小时前
二叉树的锯齿层序遍历
数据结构·算法
covco6 小时前
星链引擎矩阵系统:分布式任务调度与万级账号批量作业自动化技术实践
分布式·矩阵·自动化·批量作业