leetcode 91:spiral-matrix-ii

题目描述

给定一个整数n,将数字1到n2n^2n2按螺旋的顺序填入n×n的矩阵
例如:
给出的n=3,
你应该返回如下矩阵:
[↵ [ 1, 2, 3 ],↵ [ 8, 9, 4 ],↵ [ 7, 6, 5 ]↵]
题目分析:
这个题属于常规题,就是旋转着给数组赋值,需要搞清楚行和列的关系,当转完一圈以后,行和列的处理。

代码如下:
 1 vector<vector<int> > generateMatrix(int n) {
 2         std::vector<std::vector<int>> v;
 3     if (n < 1)
 4         return v;
 5 
 6     for (int i = 0; i < n; i++)
 7     {
 8         std::vector<int> t(n);
 9         v.push_back(t);
10     }
11 
12     int num = 1;
13     int rowStart = 0, rowEnd = n - 1, colStart = 0, colEnd = n - 1;
14     while (num <= n*n)
15     {
16         for (int i = colStart; i <= colEnd; i++)
17         {
18             v[rowStart][i] = num++;
19         }
20         for (int i = rowStart + 1; i <= rowEnd; i++)
21         {
22             v[i][colEnd] = num++;
23         }
24         for (int i = colEnd - 1; i >= colStart; i--)
25         {
26             v[rowEnd][i] = num++;
27         }
28         
29         for (int i = rowEnd - 1; i > rowStart; i--)
30         {
31             v[i][colStart] = num++;
32         }
33         rowStart++;
34         rowEnd--;
35         colStart++;
36         colEnd--;
37     }
38 
39     return v;
40     }

 



posted @ 2020-08-11 13:31  请叫我小小兽  阅读(133)  评论(0编辑  收藏  举报