leetcode分类刷题:矩阵顺时针模拟

2023-11-06

1、这种题目是对代码熟练度考察,模拟顺时针建立或访问矩阵,需要注意矩阵是否为方阵
2、具体思路:以圈数为循环条件,每一圈都坚持左闭右开的区间规则;当小的行列值为奇数,最后一圈为一行或一列或一个数字的不完整圈
3、细节:把 起始圈的上下左右边界 和 i,j标记矩阵的赋值位置 放在圈数循环外部,以方便完整圈数遍历完后使用这些变量;同时,圈数循环内部的最后要对这些变量进行更新

59. 螺旋矩阵 II

from typing import List
'''
59. 螺旋矩阵 II
题目描述:给你一个正整数 n ,生成一个包含 1 到 n^2 的所有元素,且元素按顺时针顺序螺旋排列的 n i n 正方形矩阵 matrii 。
示例 1:
    输入:n = 3
    输出:[[1,2,3],[8,9,4],[7,6,5]]
题眼:代码熟练度考察,模拟顺时针建立矩阵,注意是方阵,复杂度降低了些
思路:以圈数为循环条件,每一圈都坚持左闭右开的区间规则;当n为奇数,恰好留了一个中心元素待更新
注意把 起始圈的上下左右边界 和 i,j标记矩阵的赋值位置 放在圈数循环外部,以方便圈数遍历完后使用这些变量;同时,圈数循环内部的最后要对这些变量进行更新
'''


class Solution:
    def generatedMatrii(self, n: int) -> List[List[int]]:
        result = [[0] * n for _ in range(n)]
        # 以圈数为循环条件,每一圈都坚持左闭右开的区间规则
        count = 1
        up, down, left, right = 0, n - 1, 0, n - 1  # 起始圈的上下左右边界
        i, j = up, left  # i,j标记矩阵的赋值位置,初始值为左上角坐标
        for _ in range(n // 2):  # 总圈数为 n // 2
            while i == up and j < right:  # 上
                result[i][j] = count
                j += 1
                count += 1
            while i < down and j == right:  # 右
                result[i][j] = count
                i += 1
                count += 1
            while i == down and j > left:  # 下
                result[i][j] = count
                j -= 1
                count += 1
            while i > up and j == left:  # 左
                result[i][j] = count
                i -= 1
                count += 1
            # 更新圈的上下左右边界
            up, down, left, right = up + 1, down - 1, left + 1, right - 1
            i, j = up, left  # i,j标记矩阵的赋值位置,初始值为左上角坐标
        # 当n为奇数,恰好留了一个中心元素待更新
        if n % 2 == 1:
            result[up][left] = count
        return result


if __name__ == "__main__":
    obj = Solution()
    while True:
        try:
            n = int(input().strip().split('=')[1])
            print(obj.generatedMatrii(n))
        except EOFError:
            break

54. 螺旋矩阵

from typing import List
'''
54. 螺旋矩阵
题目描述:给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。
示例 1:
    输入:matrix = [[1,2,3],[4,5,6],[7,8,9]]
    输出:[1,2,3,6,9,8,7,4,5]
题眼:代码熟练度考察,模拟顺时针返回矩阵元素,注意不是方阵,有点复杂度
思路:以圈数为循环条件,每一圈都坚持左闭右开的区间规则;当小的行列值为奇数,最后一圈为一行或一列或一个数字的不完整圈
注意把 起始圈的上下左右边界 和 i,j标记矩阵的赋值位置 放在圈数循环外部,以方便圈数遍历完后使用这些变量;同时,圈数循环内部的最后要对这些变量进行更新
'''


class Solution:
    def spiralOrder(self, matrix: List[List[int]]) -> List[int]:
        m, n = len(matrix), len(matrix[0])
        result = []
        # 以圈数为循环条件,每一圈都坚持左闭右开的区间规则
        up, down, left, right = 0, m - 1, 0, n - 1  # 起始圈的上下左右边界
        i, j = up, left  # i,j标记矩阵的赋值位置,初始值为左上角坐标
        for _ in range(min(m, n) // 2):  # 总圈数为 小的行列值除以2
            while i == up and j < right:  # 上
                result.append(matrix[i][j])
                j += 1
            while i < down and j == right:  # 右
                result.append(matrix[i][j])
                i += 1
            while i == down and j > left:  # 下
                result.append(matrix[i][j])
                j -= 1
            while i > up and j == left:  # 左
                result.append(matrix[i][j])
                i -= 1
            # 更新圈的上下左右边界
            up, down, left, right = up + 1, down - 1, left + 1, right - 1  # 起始圈的上下左右边界
            i, j = up, left  # i,j标记矩阵的赋值位置,初始值为左上角坐标
        # 当小的行列值为奇数,最后一圈为一行或一列或一个数字的不完整圈
        if min(m, n) % 2 == 1:
            if up == down and left == right:  # 一个数字
                result.append(matrix[up][left])
            elif up != down and left == right:  # 一列,对应的列索引为left
                for k in range(up, down + 1):
                    result.append(matrix[k][left])
            elif up == down and left != right:  # 一行,对应的行索引为up
                for k in range(left, right + 1):
                    result.append(matrix[up][k])
        return result


if __name__ == "__main__":
    obj = Solution()
    while True:
        try:
            in_line = input().strip().split('=')
            matrix = []
            for row in in_line[1].strip()[1: -1].split(']')[: -1]:
                matrix.append([int(n) for n in row.split('[')[1].split(',')])
            print(obj.spiralOrder(matrix))
        except EOFError:
            break
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

leetcode分类刷题:矩阵顺时针模拟 的相关文章

  • collection 转Map

    public static
  • 华为android如何删除,华为手机内存中的“其他”能删除吗?现在就来揭秘

    原标题 华为手机内存中的 其他 能删除吗 现在就来揭秘 安卓手机用了不到两个月 其他 类数据占了10G 我相信不仅仅你一个人会遇到这种情况 如果你经常使用手机 那设备的存储空间当中肯定有很大一部分被归为 其他 类的数据所占据 用的时间越久
  • 字符串7:重复的子字符串

    主要是我自己刷题的一些记录过程 如果有错可以指出哦 大家一起进步 转载代码随想录 原文链接 代码随想录 leetcode链接 459 重复的子字符串 题目 给定一个非空的字符串 s 检查是否可以通过由它的一个子串重复多次构成 示例 示例 1
  • ug12.0安装教程以及UG12许可证安装

    ug12 0安装教程以及UG12许可证安装 附中文版百度云下载地址 知乎 zhihu com 参考该文章 切记 如果忘了修改 安装完成后 计算机右键 属性 高级 环境变量 系统变量中找到SPLM LICENSE 编辑 将值改为27800
  • MMEditing 介绍——注册器

    目录 什么是注册器 注册器工作原理 为什么要用注册器 MMEditing 中的注册器 注册器带来的不便如何解决 什么是注册器 python 的 register 可以理解为一个字典 字典中存储了 class function 的名称和内容
  • UE4之接口

    参考 https docs unrealengine com zh CN Programming UnrealArchitecture Reference Interfaces index html 接口的模式比较固定 下面就上我定义的接口

随机推荐

  • Tomcat中常见线程说明

    本文讲述了Tomcat的常见线程的功能 名称 线程池和配置等信息 其中源码来自于Tomcat 6 0 18 Work线程 功能 HTTP请求的处理线程 非NIO 当有新的http请求进来后 则会从线程池中获得一个线程Work对象 调用Wor
  • 什么是webhook?

    1 什么是webhook webhooks是一个api概念 是微服务api的使用范式之一 也被成为反向api 即 前端不主动发送请求 完全由后端推送 举个常用例子 比如你的好友发了一条朋友圈 后端将这条消息推送给所有其他好友的客户端 就是
  • 国内VS Code下载速度慢

    在知乎上面看到一个非常有效的方法 原链接 国内下载vscode速度慢问题解决 知乎 具体方法如下 1 直接百度搜索VS CODE 点击下载后获取下载链接 2 取出链接 并替换原链接中域名为vscode cdn azure cn 将新链接粘贴
  • 学习Spring

    1 如何学习Spring 你可以通过下列途径学习spring 1 spring下载包中doc目录下的MVC step by step和sample目录下的例子都是比较好的spring开发的例子 2 AppFuse集成了目前最流行的几个开源轻
  • STM32命名规则

    STM32型号命名规则如下 STM32型号的说明 以STM32F103ZET6这个型号的芯片为例 该型号的组成为7个部分 其命名规则如下 1 STM32 STM32代表ARM Cortex M3内核的32位微控制器 2 F F代表芯片子系列
  • Java 基础语法

    使用ide来进行编程 对于java来说 最好的idle 是intellijidea IDEA 通过一个例子练习 idea 一 超市管理系统功能 使用ide来进行编程 java最好的ide 是idea 1 import java util A
  • python--字典概念以及基本使用 -- 小黑学习驿站

    字典应用案例 697条消息 python 商店购物案例 字典篇 小黑学习驿站 小黑日志的博客 CSDN博客 697条消息 python学习 计算学生成绩排名案例 字典篇2 小黑学习驿站 小黑日志的博客 CSDN博客 字典基本概念 映射关系
  • 关于渠道包

    渠道包指的是在各大应用市场 发布的apk包的清单文件中 某个meta data标签下 配置的value不一样 这个标签的作用就是用来区分是哪个市场的 比如你发布到360 这个值就是你就可以配置成360 豌豆荚就可以配置成wandoujia
  • 微信小程序云开发之——网页跳转小程序

    一 微信小程序开通云开发 微信小程序公众平台拿到如下参数 你的小程序信息 小程序 AppID 填入你的小程序 AppID 云开发环境 ID 填入你的开通了静态网站托管的云开发环境 ID 想要拉取的小程序信息 小程序原始账号 ID 填入要跳转
  • 微信小程序授权登录详解

    文章目录 流程 wx login auth code2Session 实战 前端代码 后端代码 流程 说明 调用 wx login 获取 临时登录凭证code 并回传到开发者服务器 调用 auth code2Session 接口 换取 用户
  • 撮合前端平台在低代码平台的落地实践

    在京东技术的发展当下 不同的业务线 不同的区域 甚至于很多触达消费者的端 正在被中台架构能力所支撑 大家都很清楚 中台建设能够带来技术的规模化效应 具有提高业务协同 加速创新和交付速度 提高系统稳定性和可靠性 降低成本和支持业务快速发展等优
  • torch.device函数

    torch device 是 PyTorch 中用于表示计算设备 如CPU或GPU 的类 它允许你在代码中指定你希望在哪个设备上执行张量和模型操作 本文主要介绍了 torch device 函数的用法和功能 本文主要包含以下内容 1 创建设
  • 怎么把一个json文件读取到java中

    要把一个 JSON 文件读取到 Java 中 可以按照以下步骤进行 导入 JSON 库 Java 中常用的 JSON 库有 Jackson Gson Fastjson 等 可以根据个人喜好和项目需求选择相应的库 并导入到项目中 读取 JSO
  • # SSM框架-->Spring

    SSM框架 gt Spring 文章目录 SSM框架 gt Spring 1 1 Spring是什么 简介 1 2 Spring 的发展 1 2 1Spring Framework的特点 1 2 2 Spring的体系结构 1 2 2 1
  • Java深究1

    此篇文章仅代表作者个人所学所悟 并不构成指导指引作用 在这篇博客之前 已经读过相当数量的Java书籍 但一直都没有去总结 如今将自己所学所悟分享出来 Java特种兵 上册 这本书的毕竟是作者的处女座 书中有太多地方感觉很肤浅 也很冗余 内容
  • python实现PCA降维

    概述 本文主要介绍一种降维方法 PCA Principal Component Analysis 主成分分析 降维致力于解决三类问题 1 降维可以缓解维度灾难问题 2 降维可以在压缩数据的同时让信息损失最小化 3 理解几百个维度的数据结构很
  • mybatis-【回顾】

    分页 减少数据得到处理量 limit分页 mybatis实现分页 接口 mapperr xml 测试 RowBounds类实现分页 分页插件PageHelper 复杂查询环境搭建 导入lombok 建实体类 建mapper接口 简历mapp
  • 使用Arduino和TB6612驱动编码电机实现测速功能

    编码电机是一种常见的电机类型 它可以通过内置的编码器精确地测量电机的转速和位置 在本文中 我们将介绍如何使用Arduino和TB6612驱动编码电机 并实现测速功能 TB6612是一种双路直流电机驱动器 适用于控制小型直流电机 我们将使用A
  • 基于MATLAB的视频运动目标检测识别

    一 课题介绍 视频图像处理技术广泛用于工业 安全 医疗 管理等领域 运动目标的检测和跟踪是图像处理技术在视频序列图像处理方面的一个重要应用 在航天 交通 机器人视觉 视频监控 公共场所客流数据监测等场合发挥着重要作用 本文介绍了一种基于MA
  • leetcode分类刷题:矩阵顺时针模拟

    1 这种题目是对代码熟练度考察 模拟顺时针建立或访问矩阵 需要注意矩阵是否为方阵 2 具体思路 以圈数为循环条件 每一圈都坚持左闭右开的区间规则 当小的行列值为奇数 最后一圈为一行或一列或一个数字的不完整圈 3 细节 把 起始圈的上下左右边