LintCode 374-螺旋矩阵 状态机

本文介绍了一种使用状态机实现的矩阵螺旋遍历算法。通过定义四种状态:左转、右转、上移和下移,并结合已访问标记矩阵来避免重复访问,实现了对二维矩阵的螺旋式遍历。

使用状态机的思路,运用四个状态来回切换,并用count计算步长最终退出。

 static public List<Integer> spiralOrder(int[][] matrix) {
        // Write your code here
        List<Integer> ret = new ArrayList<>();
        if (matrix.length == 0) return ret;


        int i = 0;
        int j = 0;
        int state = 2;
        int maxstep = matrix.length * matrix[0].length;
        int count = 0;
        final int TURNLEFT = 1, TURNRIGHT = 2, TURNUP = 3, TURNDOWM = 4;//定义了四种状态
        int visited[][] = new int[matrix.length][matrix[0].length];//定义一个已走过的矩阵
        while (count < matrix.length * matrix[0].length) {
            int temp = matrix[i][j];


            count++;//每走一次都加一

            switch (state) {

                case TURNLEFT: {
                    ret.add(temp);
                    visited[i][j] = 1;
                    if (j == 0 || visited[i][j - 1] == 1) {
                        i--;
                        state = TURNUP;
                    }
                    else {
                        j--;
                        state = TURNLEFT;
                    }

                    break;
                }
                case TURNRIGHT: {
                    ret.add(temp);
                    visited[i][j] = 1;
                    if (j + 1 == matrix[0].length || visited[i][j + 1] == 1) {
                        state = TURNDOWM;
                        i++;
                    }
                    else {

                        j++;
                        state = TURNRIGHT;
                    }

                    break;
                }
                case TURNUP: {
                    ret.add(temp);
                    visited[i][j] = 1;
                    if (i == 0 || visited[i - 1][j] == 1) {
                        j++;
                        state = TURNRIGHT;
                    }
                    else {
                        i--;
                        state = TURNUP;
                    }

                    break;
                }
                case TURNDOWM: {
                    ret.add(temp);
                    visited[i][j] = 1;
                    if (i + 1 == matrix.length || visited[i + 1][j] == 1) {
                        j--;
                        state = TURNLEFT;
                    }
                    else {
                        i++;
                        state = TURNDOWM;
                    }

                    break;

                }
            }
        }

    return ret;
    }
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值