您的位置:首页 > 文旅 > 美景 > Leetcode面试经典150题-54.螺旋矩阵

Leetcode面试经典150题-54.螺旋矩阵

2024/12/23 3:52:22 来源:https://blog.csdn.net/Chang_Yafei/article/details/141873399  浏览:    关键词:Leetcode面试经典150题-54.螺旋矩阵

  解法都在代码里,不懂就留言或者私信

这个题可能和算法关联不大,coding技巧为上

class Solution {public List<Integer> spiralOrder(int[][] matrix) {/**先定义结果集 */List<Integer> ans = new ArrayList<>();/**当前位置从(0,0)开始 */int curRow = 0;int curCol = 0;Set<Integer> existsSet = new HashSet<>();/**direction表示当前运动的方向,理论上应该先往右,左边走不动了往下,下面走不动了往左 左边走不动了网上,这里我们定义0,1,2,3分别代表右下左上四个方向*/int direction = 0;/**count表示矩阵中共有多少个数字 */int count = matrix.length * matrix[0].length; ans.add(matrix[0][0]);existsSet.add(0);/**已经加了一个点 */int curCount = 1;/**还没有收集够所有的就继续 */while(curCount < count) {/**根据方向确定下一个点走哪里*/int rowNext = curRow;int colNext = curCol;/**根据方向不同确定行列的变化 */switch(direction) {case 0: colNext ++;break;case 1: rowNext ++;break;case 2:colNext --;break;case 3:rowNext --;break;}if(!existsSet.contains(rowNext*matrix[0].length + colNext) && rowNext >= 0 && colNext >= 0 && rowNext < matrix.length && colNext < matrix[0].length) {curRow = rowNext;curCol = colNext;/**把当前位置加进去 */ans.add(matrix[curRow][curCol]);existsSet.add(curRow*matrix[0].length + curCol);curCount ++;} else {/**如果这个位置已经存在了或者越界了,变向 */direction = (direction + 1)%4;}}return ans;}   
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com