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

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

题目链接:点击打开链接


题目大意:略。


解题思路:略。


相关企业


哔哩哔哩

字节跳动

苹果(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;
    }
};
目录
相关文章
|
2月前
|
算法
测试工程师的技能升级:LeetCode算法挑战与职业成长
这篇文章通过作者亲身体验LeetCode算法题的过程,探讨了测试工程师学习算法的重要性,并强调了算法技能对于测试职业成长的必要性。
49 1
测试工程师的技能升级:LeetCode算法挑战与职业成长
|
2月前
|
算法
LeetCode第59题螺旋矩阵 II
LeetCode第59题"螺旋矩阵 II"的解题方法,通过模拟螺旋填充过程,一圈一圈从外到内按顺序填充数字,直到完成整个矩阵的构建。
LeetCode第59题螺旋矩阵 II
|
2月前
|
存储 算法
LeetCode第54题螺旋矩阵
LeetCode第54题"螺旋矩阵"的解题方法,通过模拟从外到内的螺旋遍历过程,并利用方向向量控制遍历方向的转换,有效输出矩阵的螺旋顺序。
LeetCode第54题螺旋矩阵
|
2月前
|
算法 Java
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
39 6
|
2月前
|
存储 算法 Java
LeetCode经典算法题:打家劫舍java详解
LeetCode经典算法题:打家劫舍java详解
55 2
|
2月前
|
人工智能 算法 Java
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
LeetCode经典算法题:井字游戏+优势洗牌+Dota2参议院java解法
41 1
|
2月前
|
存储 算法 Java
LeetCode经典算法题:预测赢家+香槟塔java解法
LeetCode经典算法题:预测赢家+香槟塔java解法
40 1
|
2月前
|
存储 算法 Java
LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
65 0
|
2月前
|
算法 Java
LeetCode初级算法题:子数组最大平均数+二叉树的最小深度+最长连续递增序列+柠檬水找零
LeetCode初级算法题:子数组最大平均数+二叉树的最小深度+最长连续递增序列+柠檬水找零
34 0
|
2月前
|
算法 Java
LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
46 0
下一篇
无影云桌面