这是LeetCode里的第54道题。

题目要求:

给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素。

示例 1:

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

示例 2:

输入:
[
[1, 2, 3, 4],
[5, 6, 7, 8],
[9,10,11,12]
]
输出: [1,2,3,4,8,12,11,10,9,5,6,7]

核心思想:

无脑用循环,设置条件,并且注意边界和圈数,进行合理的控制。走一圈如下图所示:

可以发现,走完一圈以后每一行(列)的边界都向里压缩了一个单位。所以主要处理好边界和数的位置。

声明right和down变量,代表右和下方向。取反则为反方向。因为取数先向右,后向下,后向左,最后向上。如此往复。

 class Solution {
public:
vector<int> spiralOrder(vector<vector<int>>& matrix) {
/*
vector<int>no;//这是为了返回空值而设置的变量
if(matrix.size()==0)return no;//没有数据返回空
if(matrix[0].size()==0)return no;//虽然有行,但是每一行都没数据,返回空
*/
if (matrix.empty() || matrix[].empty()) return {};//以上代码合并
int n=matrix.size(),m=matrix[].size();//n为行数,m为列数
vector<int>res(n*m,);//大小为n*m,并初始化为0的线性表
int times=;//记录走了几圈
int right=,down=,i=,j=,ii=,jj=;
for(ii=;ii<n;ii++){
for(jj=;jj<m;jj++){
res[ii*m+jj]=matrix[i][j];
if(j<m-times&&i==times){
if(j==m-times-){i=i+down;continue;}//判断是否走到了边界,下走
j=j+right;}//右走
else if (i<n-times&&j==m-times-){
if (i==n-times-){j=j-right;continue;}//判断是否走到了边界,左走
i=i+down;}//下走
else if(j>=&&i==n-times-){
if(j==times){i =i-down;continue;}//判断是否走到了边界,上走
j=j-right;}//左走
else if(i>=&&j==times){
if(i==times+){j=j+right;times++;continue;}//判断是否走到了边界,右走
i=i-down;}//上走
}
}
return res;
}
};

运行结果:

个人总结: 
因为我之前写过这个题目,所以做起来思路还是很清晰的,我个人认为,我这个算法缺点在于判断次数过多。不够简洁。之前是用的上下左右四个边界设值来判断拐弯条件。代码没有那么复杂也更好理解,而且这里要求返回的结果是一维的数组,而之前做的题目要求返回的是二维数组,这道题难度降低了点。

【LeetCode】Spiral Matrix(螺旋矩阵)的更多相关文章

  1. [LeetCode] Spiral Matrix 螺旋矩阵

    Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral or ...

  2. [算法][LeetCode]Spiral Matrix——螺旋矩阵

    题目要求 Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spir ...

  3. Leetcode 54:Spiral Matrix 螺旋矩阵

    54:Spiral Matrix 螺旋矩阵 Given a matrix of m x n elements (m rows, n columns), return all elements of t ...

  4. leetCode 54.Spiral Matrix(螺旋矩阵) 解题思路和方法

    Spiral Matrix Given a matrix of m x n elements (m rows, n columns), return all elements of the matri ...

  5. PAT甲级——1105 Spiral Matrix (螺旋矩阵)

    此文同步发布在CSDN:https://blog.csdn.net/weixin_44385565/article/details/90484058 1105 Spiral Matrix (25 分) ...

  6. [leetcode]54. Spiral Matrix螺旋矩阵

    Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral or ...

  7. 第29题:LeetCode54:Spiral Matrix螺旋矩阵

    给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7, 8, 9 ...

  8. Leetcode54. Spiral Matrix螺旋矩阵

    给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7, 8, 9 ...

  9. spiral matrix 螺旋矩阵

    Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral or ...

随机推荐

  1. 修复在unix系统里的文件打开不能显示正常的颜色问题

    在mac上面看到mysql的配置文件的颜色永远是白色,为了让配置文件的颜色更加分明些,这个时候只需进入到home目录下新建一个.vimrc文件, vim  .vimrc set nu syntax o ...

  2. 090 Subsets II 子集 II

    给定一个可能包含重复整数的列表,返回所有可能的子集(幂集).注意事项:解决方案集不能包含重复的子集.例如,如果 nums = [1,2,2],答案为:[  [2],  [1],  [1,2,2],  ...

  3. keil_rtx特点

    Keil RTX是一个专为ARM及Cortex M系列处理器开发的无版税的确定的实时操作系统.它允许工程师建立多任务同步并行的程序软件,同时也能帮助使程序代码更加结构化和便于维护.   产品亮点 所有 ...

  4. CD4051的切换时间

    CD4051:1 2 4 5 12 13 14 15  8个选择IO输入/输出端:3:I/O6:片选低电平有效,搞定平所有通道不通9 10 11:地址选择:功能:通过地址选择译码8个中的某个通道与3脚 ...

  5. JS=和==和===的区别

    1. = : 赋值运算,赋值使用2.== :比较运算,仅比较自动转换后的值是否相等,忽略 变量类型,如:'1' == 1 //true 3.=== : 比较运算,比较值和变量类型是否相等,如:'1' ...

  6. 关于nodejs模块安装后找不到包解决办法

    主要原因是类似bower.gulp这些包后,没有添加到环境变量,但是有洁癖的我也不希望添加太多的软链接,所以在用phpstorm开始时有需要的情况下 定义临时的环境变量 http://stackove ...

  7. codeforces736D. Permutations(线性代数)

    题意 $m \leqslant 500000$,题目打错了 Sol 神仙题Orz 构造矩阵$B$,使得$B[b[i]][a[i]] = 1$ 那么他的行列式的奇偶性也就对应了生成排列数列数量的奇偶性( ...

  8. 动手使用ABAP Channel开发一些小工具,提升日常工作效率

    今天的故事要从ABAP小游戏说起. 中国的ABAP从业者们手头或多或少都搜集了一些ABAP小游戏,比如下面这些. 消灭星星: 扫雷: 来自我的朋友刘梦,公众号"SAP干货铺"里的俄 ...

  9. Servlet Context

    Servlet Context Container Provider 负责提供ServletContext的实现. A ServletContext is rooted at a known path ...

  10. 更新Svn客户端后,右键菜单中没有TortoiseSVN

    环境: OS:                 Windows XP sp3 升级后SVNServer:    VisualSVN Server 2.7.3 升级后SVNClient:    小乌龟: ...