栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

LeetCode(剑指 Offer)- 29. 顺时针打印矩阵

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

LeetCode(剑指 Offer)- 29. 顺时针打印矩阵

题目链接:点击打开链接

题目大意:略。

解题思路:略。

相关企业

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

AC 代码

Java

// 解决方案(1)
class Solution {
    public int[] spiralOrder(int[][] matrix) {
        if(matrix.length == 0) return new int[0];
        int l = 0, r = matrix[0].length - 1, t = 0, b = matrix.length - 1, x = 0;
        int[] res = new int[(r + 1) * (b + 1)];
        while(true) {
            for(int i = l; i <= r; i++) res[x++] = matrix[t][i]; // left to right
            if(++t > b) break;
            for(int i = t; i <= b; i++) res[x++] = matrix[i][r]; // top to bottom
            if(l > --r) break;
            for(int i = r; i >= l; i--) res[x++] = matrix[b][i]; // right to left
            if(t > --b) break;
            for(int i = b; i >= t; i--) res[x++] = matrix[i][l]; // bottom to top
            if(++l > r) break;
        }
        return res;
    }
}

// 解决方案(2)
class Solution {

    public int[] spiralOrder(int[][] matrix) {
        if (matrix.length == 0) return new int[0];
        int m = matrix.length, n = matrix[0].length;
        final int[] direct = {6, 2, 4, 8};
        int[][] block = new int[m][n];
        int[] res = new int[m * n];
        int i = 0, j = 0, q = 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;
                res[q++] = 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;
                res[q++] = 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;
                res[q++] = matrix[i][j--];
            } else { // UP
                if (i < 0 || block[i][j] == 1) {
                    p = (p + 1) % 4;
                    i++;
                    j++;
                    continue;
                }
                block[i][j] = 1;
                res[q++] = matrix[i--][j];
            }
            if (q == m * n) {
                break;
            }
        }
        return res;
    }
}

C++

class Solution {
public:
    vector spiralOrder(vector>& matrix)
    {
        if (matrix.empty()) return {};
        int l = 0, r = matrix[0].size() - 1, t = 0, b = matrix.size() - 1;
        vector 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;
    }
};
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/756824.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号