给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。
输入: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]
提示:
m == matrix.length
n == matrix[i].length
1 <= m, n <= 10
-100 <= matrix[i][j] <= 100
fun spiralOrder(matrix: Array<IntArray>): List<Int> {
val row = matrix.size
val col = matrix[0].size
val list = mutableListOf<Int>()
val direction = listOf(intArrayOf(0, 1), intArrayOf(1, 0), intArrayOf(0, -1), intArrayOf(-1, 0))
val visited = Array(row) { BooleanArray(col) { false } }
var dIndex = 0
var curRow = 0
var curCol = 0
while (list.size < row * col) {
list.add(matrix[curRow][curCol])
visited[curRow][curCol] = true
val nextRow = curRow + direction[dIndex][0]
val nextCol = curCol + direction[dIndex][1]
if (nextRow >= row || nextRow < 0 ||
nextCol >= col || nextCol < 0 ||
visited [nextRow][nextCol]
) {
dIndex = (dIndex + 1) % 4
}
curRow += direction[dIndex][0]
curCol += direction[dIndex][1]
}
return list
}
百尺竿头更进一步是很难的,编程这玩意,新东西学的快不快,得看业务。
谁有功夫鼓励谁啊?只能自己鼓励自己, 自己夸奖自己,让自己往前发展。
自己安慰自己
终于做出来了 看题解做出来的 是不是没有体会到数学的乐趣??
在这个急功近利的时代,很不得一天做10道算法题,
那得真没必要。还不如认真的钻研一道题的同事,感受慢节奏的快乐。
无聊的生活 终于懂得那帮人为什么每天来一道算法题了
只有算法是不变的,值得深入学习的