题解 | #螺旋矩阵#

螺旋矩阵

http://www.nowcoder.com/practice/7edf70f2d29c4b599693dc3aaeea1d31

import java.util.ArrayList;
public class Solution {
    // 四中状态的
    enum Status {
        LeftToRight, TopToBottom, RightToLeft, BottomToTop
    }

    private int[][] init(int row, int col) {
        int[][] visited = new int[row][col];
        for (int i = 0; i < visited.length; i++) {
            for (int j = 0; j < visited[0].length; j++) {
                visited[i][j] = 0; // unvisited
            }
        }
        return visited;
    }

    private boolean hasUnVisitedElement(int[][] visited) {
        for (int i = 0; i < visited.length; i++) {
            for (int j = 0; j < visited[0].length; j++) {
                if (visited[i][j] == 0) return true;
            }
        }
        return false;
    }

    public ArrayList<Integer> spiralOrder(int[][] matrix) {
        ArrayList<Integer> result = new ArrayList<>();
        if(matrix.length==0) return result;
        else if(matrix.length == 1){
            for (int i = 0; i < matrix[0].length; i++) {
                result.add(matrix[0][i]);
            }
            return result;
        }
        // 定义状态序列
        Status[] arrs = new Status[]{Status.LeftToRight, Status.TopToBottom, Status.RightToLeft, Status.BottomToTop};
        int currentStatus = 0; // 定义状态指针
        // 初始化访问矩阵
        int[][] visited = init(matrix.length, matrix[0].length);

        int left = -1, right = matrix[0].length, top = -1, bottom = matrix.length;

        // 还有未访问的就继续
        while (hasUnVisitedElement(visited)) {
            switch (arrs[currentStatus]) {
                case LeftToRight:
                    left++;
                    top++;
                    for (int i = left; i < right - 1; i++) {
                        if(visited[top][i] == 0){
                            result.add(matrix[top][i]);
                            visited[top][i] = 1; // 访问过
                        }
                    }
                    break;
                case TopToBottom:
                    right--;
                    bottom--;
                    for (int i = top; i < bottom; i++) {
                        if(visited[i][right] == 0){
                            result.add(matrix[i][right]);
                            visited[i][right] = 1;
                        }
                    }
                    break;
                case RightToLeft:
                    for (int i = right; i > left - 1; i--) {
                        if(visited[bottom][i] == 0){
                            result.add(matrix[bottom][i]);
                            visited[bottom][i] = 1;
                        }
                    }
                    break;
                case BottomToTop:
                    for (int i = bottom - 1; i > top; i--) {
                        if(visited[i][left] == 0){
                            result.add(matrix[i][left]);
                            visited[i][left] = 1;
                        }
                    }
                    break;
            }
            currentStatus = (currentStatus + 1) % arrs.length;
        }
        return result;
    }
}

值得注意的是,需要导入ArrayList的包才行。

全部评论

相关推荐

12-19 16:52
门头沟学院
点赞 评论 收藏
分享
八极星:有什么不能问的,(/_\),这又不是多珍贵的机会,你有什么可失去的
点赞 评论 收藏
分享
12-08 07:42
门头沟学院 Java
27届末九,由于是女生,身边人几乎没有就业导向的,自学只能跟着网课,没人指导,很迷茫。下图是我目前的简历,不知道有需要修改的地方吗?求拷打。下面是目前的学习情况:目前算法过完了一遍力扣100和代码随想录,不过不是很熟,面经看了小林coding、JavaGuide,有一些没用过的技术看得不是很明白,掌握得不是很扎实。再加上常年跟黑马网课听思路,真正自己动手写代码的时间很少,这让我一直不敢投简历,总觉得内里空虚。项目没准备好面试相关的问题,简历上相应的考点不熟。如此种种。。。看到很多很多学长学姐大佬们的面经,愈发觉得面试可怕,自己没准备好,总担心自己是不是无望后端开发了。看到牛客很多同届以及更小一届的同学都找到实习了,很希望自己也能找到实习。而自己又好像摸不到后端学习的门路,只能不断赞叹黑马虎哥写的代码真优雅!微服务架构实在巧妙!消息队列、redis、sentinel、nacos、mybatisplus等等的引入都会让我赞叹这些工具的设计者的巧思,以及包括但不限于Java语言的优雅。然而只是停留在了解的程度,并不熟练。我是很希望能够继续深入探索这些知识的,只不过有一大部分时间都花在学校课程上了。我感觉我被困住了,我一方面必须保证我能够有个不错的学业分使我能有我几乎不想选择的读研退路(还有个原因是复习不全我会焦虑考试挂科,因此我会做好全面的准备,而这一步很费时间),一方面在B站学习各种网课,一方面得考虑提升自己并不扎实的算法基础,另一方面还得准备八股面经。这让我有点苦恼,我好像没那么多时间,因为绝大部分时间都花在了复习学校科目中了。我好像处处用时间,但收效甚微。想问问各位大佬是怎么平衡时间的呢?算法、项目和八股是怎么准备的呢?有什么高效的方法吗?谢谢您们花时间阅读我的稿件!
菜菜狗🐶:大胆投,我当时也是害怕面试,投多了发现根本约不到面🤡
投递哔哩哔哩等公司6个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务