算法---螺旋矩阵

题目

给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。

示例 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]

提示:

m == matrix.length

n == matrix[i].length

1 <= m, n <= 10

-100 <= matrix[i][j] <= 100

解决思路

解决方法

kotlin 复制代码
    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道算法题,

    那得真没必要。还不如认真的钻研一道题的同事,感受慢节奏的快乐。

  • 无聊的生活 终于懂得那帮人为什么每天来一道算法题了

  • 只有算法是不变的,值得深入学习的

相关推荐
吃好睡好便好6 小时前
用while循环语句求和
开发语言·学习·算法·matlab·信息可视化
王璐WL6 小时前
【C语言入门级教学】函数的概念2
c语言·数据结构·算法
不知名的忻7 小时前
B 树与 B+ 树:面试完全指南
b树·算法·面试·b+树
运筹vivo@8 小时前
2657. 找到两个数组的前缀公共数组 | 难度:中等
算法·leetcode·职场和发展·哈希表
索木木8 小时前
NCCL SHARP 和 TREE算法
java·服务器·算法
oo哦哦8 小时前
2026年多平台内容管理系统技术选型:从架构设计到工程落地
人工智能·线性代数·矩阵
心中有国也有家9 小时前
hccl 架构拆解:昇腾集合通信库到底在做什么?
人工智能·经验分享·笔记·分布式·算法·架构
小O的算法实验室10 小时前
2026年MCS,Q-learning增强MOPSO与改进DWA融合算法+复杂三维地形下特定移动机器人动态路径规划
算法
2601_9578793310 小时前
短视频矩阵的数据驱动运营:从流量监测到内容迭代的完整技术链路
大数据·矩阵·音视频
Peter·Pan爱编程10 小时前
10. new_delete 不是 malloc_free 的包装
c++·人工智能·算法