『Leetcode』Spiral Matrix

Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral order.

For example,
Given the following matrix:

[
  [1, 2, 3]
  [4, 5, 6]
  [7, 8, 9]
]

You should return [1,2,3,6,9,8,7,4,5].

Solution

  这是个比较简单的题目,难度为Medium。较为简单的思路即我们完全按照题目中的要求来不断遍历整个矩阵,每次遍历一圈,然后逐渐缩小。

  每次遍历都从左上角 (x,y) 开始,按照(x,y) → (x,n-y-1) → (m-x-1,n-y-1) → (m-x-1,y) 的顺序,然后x,y分别加1,直到m/2或者n/2,代码就不贴了。

  这里额外提供一种思路,虽然实现起来和最后的效果和上面完全相同。

  仔细阅读问题中遍历的方向,发现这个遍历方向有个优先级循环,即上 > 右 > 下 > 左 > 上, 有了这个优先级顺序以后,我们就可以更加简单的实现代码,而不必去计算每次走的步数。

​  代码如下:

public class Solution {
    public List<Integer> spiralOrder(int[][] matrix) {     
        List<Integer> result = new ArrayList<Integer>();
        if(matrix.length == 0 || matrix[0].length == 0)
            return result;

        int rows = matrix.length;
        int columns = matrix[0].length;

        int totalNum = rows*columns;
        int[][] mark = new int[rows][columns];

        int x = 0;
        int y = 0;
        for(int i = 0; i < totalNum; i ++){
            result.add(matrix[x][y]);
            mark[x][y] = 1;
            //If satisfy leftforward and upfoward, left should be selected
            if(x > 0 && mark[x-1][y] == 0 && y > 0 && mark[x][y-1] == 0){
                y = y -1;
                continue;
            }
            //up
            if(x > 0 && mark[x-1][y] == 0){
                x = x-1;
                continue;
            }
            //right
            if(y < columns-1 && mark[x][y+1] == 0){
                y = y+1;
                continue;
            }
            //down 
            if(x < rows-1 && mark[x+1][y] == 0){
                x = x+1;
                continue;
            }
            //left
            if(y > 0 && mark[x][y-1] == 0){
                y = y-1;
                continue;
            }
        }

        return result;
    }
}

AC!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值