LeetCode 54.Spiral Matrix (螺旋矩阵)

ゝ一世哀愁。 2022-05-10 03:46 331阅读 0赞

题目描述:

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

示例 1:

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

示例 2:

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

AC C++ Solution:

  1. class Solution {
  2. public:
  3. vector<int> spiralOrder(vector<vector<int>>& matrix) {
  4. vector<int> res;
  5. if(matrix.size() == 0) {
  6. return res;
  7. }
  8. int rowBegin = 0;
  9. int rowEnd = matrix.size()-1;
  10. int colBegin = 0;
  11. int colEnd = matrix[0].size()-1;
  12. while(rowBegin <= rowEnd && colBegin <= colEnd) {
  13. //向右遍历
  14. for (int i = colBegin; i <= colEnd; i++)
  15. res.push_back(matrix[rowBegin][i]);
  16. rowBegin++;
  17. //向下遍历
  18. for (int i = rowBegin; i <= rowEnd; i++)
  19. res.push_back(matrix[i][colEnd]);
  20. colEnd--;
  21. //向左遍历
  22. if(rowBegin <= rowEnd) {
  23. for(int i = colEnd; i >= colBegin; i--)
  24. res.push_back(matrix[rowEnd][i]);
  25. }
  26. rowEnd--;
  27. //向上遍历
  28. if(colBegin <= colEnd) {
  29. for(int i = rowEnd; i >= rowBegin; i--)
  30. res.push_back(matrix[i][colBegin]);
  31. }
  32. colBegin++;
  33. }
  34. return res;
  35. }
  36. };

发表评论

表情:
评论列表 (有 0 条评论,331人围观)

还没有评论,来说两句吧...

相关阅读