LeetCode(算法)- 54. 螺旋矩阵

本文介绍了两种解决矩阵螺旋顺序遍历问题的Java和C++实现方案。这两种方法分别通过移动边界和标记已访问元素来实现螺旋遍历,将矩阵元素按螺旋顺序添加到结果列表中。该算法适用于处理二维数组,对于理解数组遍历和递归思想具有一定的参考价值。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目链接:点击打开链接

题目大意:略。

解题思路:略。

相关企业

  • 哔哩哔哩
  • 字节跳动
  • 苹果(Apple)
  • 微软(Microsoft)
  • 谷歌(Google)
  • 彭博(bloomberg)
  • Facebook
  • 亚马逊(Amazon)
  • 甲骨文(Oracle)
  • VMware
  • 兴业银行

AC 代码

  • Java
// 解决方案(1)
class Solution {

    public List<Integer> spiralOrder(int[][] matrix) {
        int m = matrix.length, n = matrix[0].length;
        final int[] direct = {6, 2, 4, 8};
        int[][] block = new int[m][n];
        List<Integer> list = new ArrayList<>();
        int i = 0, j = 0, p = 0, dir;
        while (true) {
            dir = direct[p];
            if (dir == 6) { // RIGHT
                if (j >= n || block[i][j] == 1) {
                    p = (p + 1) % 4;
                    j--;
                    i++;
                    continue;
                }
                block[i][j] = 1;
                list.add(matrix[i][j++]);
            } else if (dir == 2) { // DOWN
                if (i >= m || block[i][j] == 1) {
                    p = (p + 1) % 4;
                    i--;
                    j--;
                    continue;
                }
                block[i][j] = 1;
                list.add(matrix[i++][j]);
            } else if (dir == 4) { // LEFT
                if (j < 0 || block[i][j] == 1) {
                    p = (p + 1) % 4;
                    j++;
                    i--;
                    continue;
                }
                block[i][j] = 1;
                list.add(matrix[i][j--]);
            } else { // UP
                if (i < 0 || block[i][j] == 1) {
                    p = (p + 1) % 4;
                    i++;
                    j++;
                    continue;
                }
                block[i][j] = 1;
                list.add(matrix[i--][j]);
            }
            if (list.size() == m * n) {
                break;
            }
        }
        return list;
    }
}

// 解决方案(2)
class Solution {
    public List<Integer> spiralOrder(int[][] matrix) {
        if(matrix.length == 0) return new ArrayList<>();
        int l = 0, r = matrix[0].length - 1, t = 0, b = matrix.length - 1;
        List<Integer> list = new ArrayList<>();
        while(true) {
            for(int i = l; i <= r; i++) list.add(matrix[t][i]); // left to right
            if(++t > b) break;
            for(int i = t; i <= b; i++) list.add(matrix[i][r]); // top to bottom
            if(l > --r) break;
            for(int i = r; i >= l; i--) list.add(matrix[b][i]); // right to left
            if(t > --b) break;
            for(int i = b; i >= t; i--) list.add(matrix[i][l]); // bottom to top
            if(++l > r) break;
        }
        return list;
    }
}
  • C++ 
class Solution {
public:
    vector<int> spiralOrder(vector<vector<int>>& matrix)
    {
        if (matrix.empty()) return {};
        int l = 0, r = matrix[0].size() - 1, t = 0, b = matrix.size() - 1;
        vector<int> res;
        while(true)
        {
            for (int i = l; i <= r; i++) res.push_back(matrix[t][i]); // left to right
            if (++t > b) break;
            for (int i = t; i <= b; i++) res.push_back(matrix[i][r]); // top to bottom
            if (l > --r) break;
            for (int i = r; i >= l; i--) res.push_back(matrix[b][i]); // right to left
            if (t > --b) break;
            for (int i = b; i >= t; i--) res.push_back(matrix[i][l]); // bottom to top
            if (++l > r) break;
        }
        return res;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

陆克和他的代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值