美文网首页
21.顺时针打印矩阵

21.顺时针打印矩阵

作者: percykuang | 来源:发表于2019-10-30 12:50 被阅读0次

题目

输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,
例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 
则依次打印出数字 1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10.

code

  // [1, 2, 3, 4, 5]
  // [6, 7, 8, 9, 10]
  // [11, 12, 13, 14, 15]
  // [16, 17, 18, 19, 20]
  // -------------------
  // [1, 2]
  // [3, 4]
  // ----------------------
  // [1]
  // [2]
  // [3]

function judgeBoundary(minRow, maxRow, minCol, maxCol) {
  return maxRow >= 0 && maxCol >= 0 && maxRow >= minRow && maxCol >= minCol
}

function printMatrix(matrix) {
  if (matrix.length < 1) return []
  if (matrix.length === 1) return matrix[0]

  var maxRow = matrix.length - 1
  var minRow = 0
  var maxCol = matrix[0].length - 1
  var minCol = 0
  var res = []
  while (judgeBoundary(minRow, maxRow, minCol, maxCol)) {
    for (var j = minCol; judgeBoundary(minRow, maxRow, minCol, maxCol) && j <= maxCol; j++) {
      res.push(matrix[minRow][j])
    }
    minRow++
    for (var j = minRow; judgeBoundary(minRow, maxRow, minCol, maxCol) && j <= maxRow; j++) {
      res.push(matrix[j][maxCol])
    }
    maxCol--
    for (var j = maxCol; judgeBoundary(minRow, maxRow, minCol, maxCol) && j >= minCol; j--) {
      res.push(matrix[maxRow][j])
    }
    maxRow--
    for (var j = maxRow; judgeBoundary(minRow, maxRow, minCol, maxCol) && j >= minRow; j--) {
      res.push(matrix[j][minCol])
    }
    minCol++
  }
  return res
}

相关文章

  • 21.顺时针打印矩阵

    题目 code

  • 【不熟练】知识迁移能力-顺时针打印矩阵

    顺时针打印矩阵 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: ...

  • 《剑指offer》— JavaScript(19)顺时针打印矩阵

    顺时针打印矩阵 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: ...

  • 剑指offer——顺时针打印矩阵

    剑指offer——顺时针打印矩阵 题目描述: 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,...

  • 矩阵

    题一:顺时针转圈打印矩阵 题二:“之“字形打印矩阵"之"字形打印矩阵两个指针:(sr,sc)先从第一行往右移动,到...

  • 《剑指offer》(十九)-顺时针打印矩阵(java)

    顺时针打印矩阵 考点:数组 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入...

  • 顺时针打印矩阵

    题目:顺时针打印矩阵(算法课第四课) 对于一个矩阵,请设计一个算法从左上角(mat[0][0])开始,顺时针打印矩...

  • 顺时针打印矩阵

    题目来源:牛客网--顺时针打印矩阵 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,...

  • 剑指Offer--顺时针打印矩阵

    顺时针打印矩阵 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X ...

  • JZ-019-顺时针打印矩阵

    顺时针打印矩阵 题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X ...

网友评论

      本文标题:21.顺时针打印矩阵

      本文链接:https://www.haomeiwen.com/subject/pmsovctx.html