力扣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;
    }
};
相关推荐
liebe1*112 分钟前
C语言程序代码(四)
c语言·数据结构·算法
进击的圆儿27 分钟前
递归专题4 - 网格DFS与回溯
数据结构·算法·递归回溯
程序猿202334 分钟前
Python每日一练---第一天:买卖股票的最佳时机
算法
夏鹏今天学习了吗1 小时前
【LeetCode热题100(56/100)】组合总和
算法·leetcode·职场和发展
ZPC82101 小时前
opencv 获取图像中物体的坐标值
人工智能·python·算法·机器人
颇有几分姿色1 小时前
密码学算法分类指南
算法·密码学
绝无仅有2 小时前
某游戏大厂的 Redis 面试必问题解析
后端·算法·面试
微笑尅乐2 小时前
三种方法解开——力扣3370.仅含置位位的最小整数
python·算法·leetcode
MMjeaty2 小时前
查找及其算法
c++·算法
寂静山林2 小时前
UVa 1597 Searching the Web
数据结构·算法