每日一题6/5

面试题29. 顺时针打印矩阵

输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。

 

示例 1:

输入:matrix = [[1,2,3],[4,5,6],[7,8,9]]
输出:[1,2,3,6,9,8,7,4,5]
示例 2:

输入:matrix = [[1,2,3,4],[5,6,7,8],[9,10,11,12]]
输出:[1,2,3,4,8,12,11,10,9,5,6,7]
 

限制:

0 <= matrix.length <= 100
0 <= matrix[i].length <= 100

 

/**
 * @param {number[][]} matrix
 * @return {number[]}
 */
/*
// 这种方法有问题,某些特殊测试用例总是会缺失 var spiralOrder = function(matrix) { if(!matrix.length) return [] let h = matrix.length, w = matrix[0].length; let res = []; for(let i=0; i<h/2; i++){ for(let j=i; j<w-i; j++){ res.push(matrix[i][j]) } for(let m=i+1; m<=h-1-i; m++){ res.push(matrix[m][w-i-1]) } for(let n=w-i-2; n>=0 && i+1<h-1; n--){ console.log('3: ',matrix[h-i-1][n]) res.push(matrix[h-i-1][n]) } for(let k=h-i-2; k>=i+1; k--){ console.log('4: ',matrix[k][i]) res.push(matrix[k][i]) } } return res }; */ var spiralOrder = function(matrix) { if (matrix == null || matrix.length == 0 || matrix[0].length == 0) { return []; } let rows = matrix.length, columns = matrix[0].length; let visited = new Array(rows) for(let i=0; i<rows; i++){ visited[i] = new Array(columns) } let total = rows * columns; let order = new Array(total); let row = 0, column = 0; let directions = [[0, 1], [1, 0], [0, -1], [-1, 0]]; let directionIndex = 0; for (let i = 0; i < total; i++) { order[i] = matrix[row][column]; visited[row][column] = true; let nextRow = row + directions[directionIndex][0], nextColumn = column + directions[directionIndex][1]; if (nextRow < 0 || nextRow >= rows || nextColumn < 0 || nextColumn >= columns || visited[nextRow][nextColumn]) { directionIndex = (directionIndex + 1) % 4; } row += directions[directionIndex][0]; column += directions[directionIndex][1]; } return order; }

 

思考:

let directions = [[0, 1], [1, 0], [0, -1], [-1, 0]]; 4个方向的题解,不容易出错,好理解,又通用
第一种解法的思路是下面的,控制4个变量往里面缩小距形。
class Solution {
    public int[] spiralOrder(int[][] matrix) {
        if (matrix == null || matrix.length == 0 || matrix[0].length == 0) {
            return new int[0];
        }
        int rows = matrix.length, columns = matrix[0].length;
        int[] order = new int[rows * columns];
        int index = 0;
        int left = 0, right = columns - 1, top = 0, bottom = rows - 1;
        while (left <= right && top <= bottom) {
            for (int column = left; column <= right; column++) {
                order[index++] = matrix[top][column];
            }
            for (int row = top + 1; row <= bottom; row++) {
                order[index++] = matrix[row][right];
            }
            if (left < right && top < bottom) {
                for (int column = right - 1; column > left; column--) {
                    order[index++] = matrix[bottom][column];
                }
                for (int row = bottom; row > top; row--) {
                    order[index++] = matrix[row][left];
                }
            }
            left++;
            right--;
            top++;
            bottom--;
        }
        return order;
    }
}

  

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/shun-shi-zhen-da-yin-ju-zhen-lcof
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

 

posted @ 2020-06-05 14:55  土豆zhang  阅读(129)  评论(0编辑  收藏  举报