首页 > 编程语言 >算法笔记:模拟过程(螺旋遍历矩阵)

算法笔记:模拟过程(螺旋遍历矩阵)

时间:2024-07-01 23:00:47浏览次数:23  
标签:遍历 matrix bottom int top 矩阵 算法 right left

1 模拟过程

“模拟过程题”通常指的是那些要求编程者通过编写代码来“模拟”或重现某个过程、系统或规则的题目。这类题目往往不涉及复杂的数据结构或高级算法,而是侧重于对给定规则的精确执行和逻辑的清晰表达。

其中螺旋遍历矩阵的题目就是一类典型的模拟过程题,需要精心设计循环和边界条件来控制遍历的方向和路径。

2 例题

题目描述

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

示例 1:

3×3

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

4×3

输入: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

题目来源

3 解法

3.1 解题思路

(1)空值处理,matrix 为空时,直接返回空列表

(2)初始化边界值 left、right、top、bottom 以及用于打印结果的列表 result

(3)循环打印矩阵,每个循环按四个方向打印,每个方向打印完成后边界内缩 1,满足终止条件则退出循环,输出 result

打印方向边界收缩打印终止条件
从左到右top 加 1top > bottom
从上到下right 减 1left > right
从右到左bottom 减 1top > bottom
从下到上left 加 1left > right

3.2 Java 代码实现

public List<Integer> spiralOrder(int[][] matrix) {
    // 空值处理
    if (matrix == null || matrix.length == 0) {
        return new ArrayList<>();
    }

    // 初始化边界值
    int left = 0;
    int right = matrix[0].length - 1;
    int top = 0;
    int bottom = matrix.length - 1;
    // 初始化结果集
    List<Integer> result = new ArrayList<>();
    // 循环打印矩阵
    while (true) {
        // 从左到右
        for (int i = left; i <= right; i++) {
            result.add(matrix[top][i]);
        }
        // top 边界内缩 1,终止条件:top > bottom
        if (++top > bottom) {
            break;
        }

        // 从上到下
        for (int i = top; i <= bottom; i++) {
            result.add(matrix[i][right]);
        }
        // right 边界内缩 1,终止条件:left > right
        if (--right < left) {
            break;
        }

        // 从右到左
        for (int i = right; i >= left; i--) {
            result.add(matrix[bottom][i]);
        }
        // bottom 边界内缩 1,终止条件:top > bottom
        if (--bottom < top) {
            break;
        }

        // 从下到上
        for (int i = bottom; i >= top; i--) {
            result.add(matrix[i][left]);
        }
        // left 边界内缩 1,终止条件:left > right
        if (++left > right) {
            break;
        }
    }

    return result;
}

4 相关题目(题目来源:Leetcode)

4.1 螺旋矩阵 II

4.1.1 题目描述

给你一个正整数 n ,生成一个包含 1n^2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix

示例 1:

img

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

示例 2:

输入:n = 1
输出:[[1]]

提示:

  • 1 <= n <= 20

题目来源

4.1.2 解题思路

(1)初始化一个 n x n 的矩阵 matrix 、边界值 left、right、top、bottom 以及填充元素值 num

(2)循环填充矩阵,每个循环按四个方向填充,每填充一个数字 num 自增 1,每个方向填充完成后边界内缩 1

填充方向边界收缩
从左到右top 加 1
从上到下right 减 1
从右到左bottom 减 1
从下到上left 加 1

(3)终止条件 num > n * n 即所有元素填充完毕,输出 matrix

4.1.3 Java 代码实现

public int[][] generateMatrix(int n) {
    // 初始化矩阵以及边界值
    int[][] matrix = new int[n][n];
    int left = 0;
    int right = n - 1;
    int top = 0;
    int bottom = n - 1;
    // 填充元素值
    int num = 1;
    // 循环填充矩阵
    while (num <= n * n) {
        // 从左到右
        for (int i = left; i <= right; i++) {
            matrix[top][i] = num++;
        }
        // top 边界内缩 1
        top++;

        // 从上到下
        for (int i = top; i <= bottom; i++) {
            matrix[i][right] = num++;
        }
        // right 边界内缩 1
        right--;

        // 从右到左
        for (int i = right; i >= left; i--) {
            matrix[bottom][i] = num++;
        }
        // bottom 边界内缩 1
        bottom--;

        // 从下到上
        for (int i = bottom; i >= top; i--) {
            matrix[i][left] = num++;
        }
        // left 边界内缩 1
        left++;
    }

    return matrix;
}

标签:遍历,matrix,bottom,int,top,矩阵,算法,right,left
From: https://blog.csdn.net/weixin_42001592/article/details/140111867

相关文章

  • 算法金 | Transformer,一个神奇的算法模型!!
    大侠幸会,在下全网同名「算法金」0基础转AI上岸,多个算法赛Top「日更万日,让更多人享受智能乐趣」抱个拳,送个礼在现代自然语言处理(NLP)领域,Transformer模型的出现带来了革命性的变化。它极大地提升了语言模型的性能和效率,而自注意力机制是其中的核心组件。今个儿我们将......
  • 二叉树层序遍历
    题目描述给你二叉树的根节点 root ,返回其节点值的 层序遍历 。(即逐层地,从左到右访问所有节点)。假设有这样一棵二叉树,那么它经过层序遍历的结果就应该是:[[3],[9,20],[15,7]]解法我们可以用广度优先搜索解决这个问题。按层打印:题目要求的二叉树的从上至下打印(即......
  • [JLU] 数据结构与算法上机题解思路分享-第二次上机
    前言首先,请务必自己尽全力尝试实现题目,直接看成品代码,思维就被拘束了,也很容易被查重。这里只是思路解析的博客,代码仓库在JLU_Data_Structures_Record希望你能在这里找到你想要的:)正文A二叉树的创建与遍历分数10作者朱允刚单位吉林大学通过带空指针信息的先根序列(......
  • 代码随想录算法训练营第九天|232.用栈实现队列、225.用队列实现栈、 20.有效的括号、1
    文章目录232.用栈实现队列思路--直接模拟225.用队列实现栈解法一、两个队列模拟解法二、一个队列模拟20.有效的括号栈模拟1047.删除字符串中的所有相邻重复项解法一、栈解法二、双指针232.用栈实现队列题目链接:232.用栈实现队列-力扣(LeetCode)题目描述:请你仅......
  • 7.1 闲话-Erdős–Gallai 定理和哈基米算法(没写完)
    前几天考试有一个建出最大流模型,转为最小割,然后模拟最小割的套路。这一个套路并不是少见的。在Gale-Ryser定理和Erdős–Gallai定理的证明都体现了这个想法。Gale-Ryser定理:我先阅读了博文的ycx060617的评论的对Gale-Ryser定理的证明,略去。Erdős–Gallai定理:非增序......
  • educoder 机器学习 --- kNN算法
    第一关:#encoding=utf8importnumpyasnpfromcollectionsimportCounterclasskNNClassifier(object):def__init__(self,k):'''初始化函数:paramk:kNN算法中的k'''self.k=k#用来......
  • 基于javaweb jsp ssm基于分类算法的学业警示预测毕业设计实战项目分享
    前言......
  • Open3D Ransac点云配准算法(粗配准)
    目录一、概述1.1简介1.2RANSAC在点云粗配准中的应用步骤二、代码实现2.1关键函数2.2完整代码2.3代码解析2.3.1计算FPFH1.法线估计2.计算FPFH特征2.3.2全局配准1.函数:execute_global_registration2.距离阈值3.registration_ransac_based_on_feature_matching函......
  • C/C++ Dijkstra(迪杰斯特拉)算法详解及源码
    Dijkstra(迪杰斯特拉)算法是一种用于寻找带权重图中的最短路径的算法。它由荷兰计算机科学家EdsgerDijkstra于1956年提出,被广泛应用于网络路由算法和地图路线规划等领域。算法思想:初始化一个距离数组,用于保存起点到每个顶点的当前最短距离(初始时将起点距离设置为0,其他顶......
  • 代码随想录算法训练营Day9 | 字符串 151.翻转字符串单词 28.实现strStr() KMP算法介绍
    python中常用:        s[::-1]: 反转整个字符        s.strip():删除开头或结尾处的空白字符     s.split():字符拆分成单词 →list    “”.join(s):list→字符串   (持续更新…) 151.翻转字符串里的单词 题目: Leetcod......