【算法系列-数组】螺旋矩阵(模拟)

news2025/1/10 20:36:15

【算法系列-数组】螺旋矩阵(模拟)

文章目录

  • 【算法系列-数组】螺旋矩阵(模拟)
    • 1. 螺旋矩阵II(LeetCode 59)
      • 1.1 思路分析🎯
      • 1.2 解题过程🎬
      • 1.3 代码示例🌰
    • 2. 螺旋矩阵(LeetCode 54)
      • 2.1 思路分析🎯
      • 2.2 解题过程🎬
      • 2.3 代码示例🌰
    • 3. 螺旋遍历二维数组(剑指Offer 146)
      • 3.1 思路分析🎯
      • 3.2 代码示例🌰

1. 螺旋矩阵II(LeetCode 59)

【题目链接】

1.1 思路分析🎯

这道题通过模拟解题,同时需要遵守循环不变量,明确好每一(行/列)走完时的边界值,如下:

  1. 左上到右上,不包括右上,右上交给下一轮开头;
  2. 右上到右下,不包括右下,右下交给下一轮开头;
  3. 右下到左下,不包括左下,左下交给下一轮开头;
  4. 左下到左上,不包括左上,此时一圈已结束;

在这里插入图片描述

若传进来的n为奇数,则最后中间都会剩一个空,此时将直接赋值arr [n / 2][n / 2] = count即可;

1.2 解题过程🎬

初始化 x为矩阵行首,y为矩阵列首 offset用来计算每次拐弯时的边界值,即每次循环都不取每行/每列的边界值,交给下一层循环作起始值,每一圈结束后offset需要 + 1; 圈数 q = n / 2,每次循环结束q–;

进入while循环,表示开始新一圈的赋值,之后通过四个for循环对矩阵的四条边进行赋值,直到四次循环结束,矩阵行首 x + 1,矩阵列首 y + 1, offset + 1,圈数 q - 1,重复上述过程直到q 为 0; 若 n 为 奇数,表示最后矩阵中间会单独剩下一个位,直接赋值即可

1.3 代码示例🌰

class Solution {
    public int[][] generateMatrix(int n) {
        int x = 0;
        int y = 0;
        int[][] arr = new int[n][n];
        int offset = 1;
        int count = 1;
        int i = 0, j = 0;
        int q = n / 2, mid = n / 2;
        while (q > 0) {
            j = y;
            i = x;
            for (;j < n - offset;j++) {
                arr[i][j] = count++;
            }
            for (;i < n - offset;i++) {
                arr[i][j] = count++;
            }
            for (;j > y;j--) {
                arr[i][j] = count++;
            }
            for (;i > x;i--) {
                arr[i][j] = count++;
            }
            x++;
            y++;
            offset++;
            q--;
        }
        if (n % 2 == 1) {
            arr[mid][mid] = count++;
        }
        return arr;
    }
}

2. 螺旋矩阵(LeetCode 54)

【题目链接】

2.1 思路分析🎯

这道题的解法与上道题目(螺旋矩阵II)存在一些区别,区别在于这道题:每次循环都取每行/每列最后的边界值,即做到每一轮的最后边界值在下一轮的开始都不会使用:

在这里插入图片描述

2.2 解题过程🎬

定义好初始数据:

l: 最左边界值

r: 最右边界值

t: 最上边界值

b:最下边界值

之后进入循环,在循环中依次进行理论循环移动:

从左到右:让索引 i = l,从左到右遍历直到 i > r,结束此轮遍历,同时 ++t,最上边界值向下移动一格并进行判断,若 t > b 则退出主循环;

从上到下:让索引 i = t,从上到下遍历直到 i > b,结束此轮遍历,同时 --r,最右边界值向左移动一格并进行判断,若 r < l 则退出主循环;

从右到左:让索引 i = r,从右到左遍历直到 i < l,结束此轮遍历,同时 --b,最下边界值向上移动一格并进行判断,若 b < t 则退出主循环;

从下到上:让索引 i = b,从下到上遍历直到 i < t,结束此轮遍历,同时 ++l,最左边界值向右移动一格并进行判断,若 l > r 则退出主循环;

直到主循环退出,返回收集好数据的列表即可

2.3 代码示例🌰

class Solution {
    public List<Integer> spiralOrder(int[][] matrix) {

        if (matrix.length == 0) {
            return new ArrayList<Integer>();
        }

        int t = 0, b = matrix.length - 1, l = 0, r = matrix[0].length - 1;
        List<Integer> list = new ArrayList<>();
        
        while (true) {

            for (int i = l;i <= r;i++) {
                list.add(matrix[t][i]);
            }
            if (++t > b) {
                break;
            }
            for (int i = t;i <= b;i++) {
                list.add(matrix[i][r]);
            }
            if (--r < l) {
                break;
            }
            for (int i = r;i >= l;i--) {
                list.add(matrix[b][i]);
            }
            if (--b < t) {
                break;
            }
            for (int i = b;i >= t;i--) {
                list.add(matrix[i][l]);
            }
            if (++l > r) {
                break;
            }
        }
        return list;
    }
}

3. 螺旋遍历二维数组(剑指Offer 146)

【题目链接】

3.1 思路分析🎯

这道题的解题思路与上道题(螺旋矩阵)基本一致

3.2 代码示例🌰

class Solution {
    public int[] spiralArray(int[][] array) {
        if (array.length == 0) {
            return new int[0];
        }

        int t = 0, b = array.length - 1, l = 0, r = array[0].length - 1;
        int[] arr = new int[(b + 1) * (r + 1)];
        int x = 0;
        while (true) {

            for (int i = l;i <= r;i++) {
                arr[x++] = array[t][i];
            }
            if (++t > b) {
                break;
            }
            for (int i = t;i <= b;i++) {
                arr[x++] = array[i][r];
            }
            if (--r < l) {
                break;
            }
            for (int i = r;i >= l;i--) {
                arr[x++] = array[b][i];
            }
            if (--b < t) {
                break;
            }
            for (int i = b;i >= t;i--) {
                arr[x++] = array[i][l];
            }
            if (++l > r) {
                break;
            }
        }
        return arr;
    }
}

以上便是对螺旋矩阵类型题的介绍了!!后续还会继续分享其它算法系列内容,如果这些内容对大家有帮助的话请给一个三连关注吧💕( •̀ ω •́ )✧( •̀ ω •́ )✧✨

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2182727.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2024/10/1 408大题专训之磁盘管理

2021&#xff1a; 2019&#xff1a; 2010&#xff1a;

网络通信——动态路由协议RIP

目录 一.动态路由协议分类 二.距离矢量路由协议 &#xff08;理解&#xff09; 三. 链路状态路由协议&#xff08;理解&#xff09; 四.RIP的工作原理 五.路由表的形成过程 六. RIP的度量值&#xff08;条数&#xff09;cost 七.RIP的版本&#xff08;v1和v2&#xff0…

基于SpringBoot+Vue的校园篮球联赛管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…

<使用生成式AI对四种冒泡排序实现形式分析解释的探讨整理>

<使用生成式AI对四种冒泡排序实现形式分析解释的探讨整理> 文章目录 <使用生成式AI对四种冒泡排序实现形式分析解释的探讨整理>1.冒泡排序实现形式总结1.1关于冒泡排序实现形式1的来源&#xff1a;1.2对四种排序实现形式使用AI进行无引导分析&#xff1a;1.3AI&…

字节终面问Transformer,就很离谱...

Transformer 是目前 NLP 甚至是整个深度学习领域不能不提到的框架&#xff0c;同时大部分 LLM 也是使用其进行训练生成模型&#xff0c;所以 Transformer 几乎是目前每一个机器人开发者或者人工智能开发者不能越过的一个框架。 接下来本文将从顶层往下去一步步掀开 Transforme…

只写CURD后台管理的Java后端要如何提升自己

你是否工作3~5年后&#xff0c;发现日常只做了CURD的简单代码。 你是否每次面试就会头疼&#xff0c;自己写的代码&#xff0c;除了日常CURD简历上毫无亮点可写 抱怨过苦恼过也后悔过&#xff0c;但是站在现在的时间点回想以前&#xff0c;发现有很多事情我们是可以做的更好的。…

宁夏众智科技OA办公系统存在SQL注入漏洞

漏洞描述 宁夏众智科技OA办公系统存在SQL注入漏洞 漏洞复现 POC POST /Account/Login?ACTIndex&CLRHome HTTP/1.1 Host: Content-Length: 45 Cache-Control: max-age0 Origin: http://39.105.48.206 Content-Type: application/x-www-form-urlencoded Upgrade-Insecur…

【C语言指南】数据类型详解(上)——内置类型

&#x1f493; 博客主页&#xff1a;倔强的石头的CSDN主页 &#x1f4dd;Gitee主页&#xff1a;倔强的石头的gitee主页 ⏩ 文章专栏&#xff1a;《C语言指南》 期待您的关注 目录 引言 1. 整型&#xff08;Integer Types&#xff09; 2. 浮点型&#xff08;Floating-Point …

C++ 游戏开发

C游戏开发 C 是一种高效、灵活且功能强大的编程语言&#xff0c;因其性能和控制能力而在游戏开发中被广泛应用。许多著名的游戏引擎&#xff0c;如 Unreal Engine、CryEngine 和 Godot 等&#xff0c;都依赖于 C 进行核心开发。本文将详细介绍 C 在游戏开发中的应用&#xff0…

【机器学习】ID3、C4.5、CART 算法

目录 常见的决策树算法 1. ID3 2. C4.5 3. CART 决策树的优缺点 优点&#xff1a; 缺点&#xff1a; 决策树的优化 常见的决策树算法 1. ID3 ID3&#xff08;Iterative Dichotomiser 3&#xff09;算法使用信息增益作为特征选择的标准。它是一种贪心算法&#xff0c;信…

Ubuntu开机进入紧急模式处理

文章目录 Ubuntu开机进入紧急模式处理一、问题描述二、解决办法参考 Ubuntu开机进入紧急模式处理 一、问题描述 Ubuntu开机不能够正常启动&#xff0c;自动进入紧急模式&#xff08;You are in emergency mode&#xff09;。具体如下所示&#xff1a; 二、解决办法 按CtrlD进…

基于SpringBoot+Vue的智能宾馆预定系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…

基于人工智能的实时健身训练分析系统:深蹲姿态识别与动作评估

关于深度实战社区 我们是一个深度学习领域的独立工作室。团队成员有&#xff1a;中科大硕士、纽约大学硕士、浙江大学硕士、华东理工博士等&#xff0c;曾在腾讯、百度、德勤等担任算法工程师/产品经理。全网20多万粉丝&#xff0c;拥有2篇国家级人工智能发明专利。 社区特色…

前端css样式设置元素的绝对定位和相对定位,要注意宽度和高度的设置

vue3子div position absolute,父div positon relative 。如果不设置子div的 width 和height,那么子div中如果数据变长,子div相对父div位置会变化。子div数据超过&#xff0c;显示... 如何实现 <template><div class"parent"><div class"child&q…

[含文档+PPT+源码等]精品大数据项目-基于Django实现的高校图书馆智能推送系统的设计与实现

大数据项目——基于Django实现的高校图书馆智能推送系统的设计与实现背景&#xff0c;可以从以下几个方面进行详细阐述&#xff1a; 一、信息技术的发展背景 随着信息技术的飞速发展和互联网的广泛普及&#xff0c;大数据已经成为现代社会的重要资源。在大数据背景下&#xf…

深入计算机语言之C++:C到C++的过度

&#x1f511;&#x1f511;博客主页&#xff1a;阿客不是客 &#x1f353;&#x1f353;系列专栏&#xff1a;从C语言到C语言的渐深学习 欢迎来到泊舟小课堂 &#x1f618;博客制作不易欢迎各位&#x1f44d;点赞⭐收藏➕关注 一、什么是C C&#xff08;c plus plus&#xff…

stm32单片机学习 - MDK仿真调试

1 进行环境配置 点击 Options for Target&#xff0c;也就是我们俗称的魔法棒。 将"C/C"中的Optimization选项选为Level 0(-O0) 作用:优化等级调为0级,便于调试时分析代码 勾选"Debug"中的Load Application at Starup 和 Run to main() 选项 作用:Load…

DBeaver详细安装与使用教程-免费的数据库管理工具

一、简介 二、安装教程 三、使用教程 1. 连接MySQL数据库 2. 查看表数据 3. 查看表属性 3. SQL编辑器和控制台 4.在DBeaver中设置定时备份数据库 一、简介 dbeaver是一款的数据库连接工具&#xff0c;免费&#xff0c;跨平台。 官网&#xff1a;DBeaver Community | …

前端——切换轮播图

学完前端js小知识后&#xff0c;动手操作的一个简单图片轮播图。 <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><meta name"keywords" content"关键词信息"><meta name"des…

数据中心交换机与普通交换机之间的区别到底在哪里?

号主&#xff1a;老杨丨11年资深网络工程师&#xff0c;更多网工提升干货&#xff0c;请关注公众号&#xff1a;网络工程师俱乐部 上午好&#xff0c;我的网工朋友。 数据中心交换被设计用来满足数据中心特有的高性能、高可靠性和可扩展性需求。 与此同时&#xff0c;普通交换机…