• 每日一题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
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

  • 相关阅读:
    java编程思想-接口总结
    java编程思想-复用类总结
    oracle dos命令
    循环插入记录,id每次加1
    android studio 的Error:No such property: packageApplicationTask for class: com.android.build.gradle.internal.variant.ApkVariantOutputData解决方法
    AngularJS 初学笔记(理论基础)
    在Linux添加PYTHONPATH方法以及修改环境变量方法
    基于Redis的三种分布式爬虫策略
    函数指针 如:void (*oper)(ChainBinTreee *p)
    typedef struct 使用
  • 原文地址:https://www.cnblogs.com/zhangzs000/p/13049732.html
Copyright © 2020-2023  润新知