LeetCode 热题 100 Day06

矩阵相关题型

Leetcode 48. 旋转图像【中等】

题意理解:

        将一个矩阵顺时针旋转90度,返回旋转后的矩阵。        

        要求: 在原地修改,不借助额外的空间

        如果可以使用辅助数组来实现转置,则有

        matrix_new[i][j]=matrix[j][row-i-1];

解题思路:

       (1) 四数循环:

        将其一层一层的进行转置

        首先看最外面的一层,将其分为红色方框中的四部分

        从第一个红色方框开始: 第一个位置(0,0)将转置到(0,2)的位置上

        原本(0,2)的位置上的数转置到(2,2),

        原来(2,2)上的数转置到(2,0)

        原来(2,0)的位置转置到(0,0)

        即: (0,0)->(0,2)->(2,2)->(2,0)->(0,2)->(0,0)

        坐标变化为: (i,j)->(j,row-i-1) 变换四次

        完成一个红色框的所有元素的变换,则完成了一层数据的转置

        如何进入下一层呢?

        i++,j++即可,重复上述操作。

        何时跳出循环:

        当且仅当,i,j指向中心元素时,跳出循环,如下图中: i=3/2=1 时,走到矩阵核心,不需要继续转置

      

        

        能不能理解更简单一些呢?

        对于四数循环的while可以从循环中展开:即实现四数互换

        

        思路二:反转替代转置

       顺时针转置90度=水平+对角线

        水平翻转: new_i,new_j=row-i-1,j

        对角线反转: new_i,new_j=j,i

1.解题【四数循环】

class Solution {
    public void rotate(int[][] matrix) {
        //使用坐标变换的逻辑,实现旋转
        int row=matrix.length,col=matrix[0].length;
        int cur_i=0,cur_j=0;
        int curVal=matrix[cur_i][cur_j];
        while(cur_i!=row/2){
            for(int j=cur_i;j<row-cur_i-1;j++){
                cur_j=j;
                curVal=matrix[cur_i][cur_j];
                int count=4;
                while(count-->0){
                    int next_i=cur_j;
                    int next_j=row-cur_i-1;
                    int nextVal=matrix[next_i][next_j];
                    matrix[next_i][next_j]=curVal;
                    
                    cur_i=next_i;
                    cur_j=next_j;
                    curVal=nextVal;
                }
            }
            cur_i++;
        }
    }
}

改进:可以将四数循环的while展开写:

class Solution {
    public void rotate(int[][] matrix) {
        //使用坐标变换的逻辑,实现旋转
        int row=matrix.length,col=matrix[0].length;
        int cur_i=0;
        while(cur_i!=row/2){
            for(int cur_j=cur_i;cur_j<row-cur_i-1;cur_j++){
                int temp=matrix[cur_i][cur_j];
                matrix[cur_i][cur_j]=matrix[row-cur_j-1][cur_i];
                matrix[row-cur_j-1][cur_i]=matrix[row-cur_i-1][row-cur_j-1];
                matrix[row-cur_i-1][row-cur_j-1]=matrix[cur_j][row-cur_i-1];
                matrix[cur_j][row-cur_i-1]=temp;
                System.out.println( matrix[cur_i][cur_j]+" "+matrix[row-cur_i-1][cur_j]+" "+matrix[row-cur_i-1][row-cur_j-1]+" "+matrix[cur_i][row-cur_j-1]);
            }
            cur_i++;
        }
    }
}

1.翻转替代转置【水平翻转+对角线翻转】

class Solution {
    public void rotate(int[][] matrix) {
        //使用坐标变换的逻辑,实现旋转
        int row=matrix.length,col=matrix[0].length;
        //水平翻转
        for(int i=0;i<row/2;i++){
            for(int j=0;j<col;j++){
                int temp=matrix[i][j];
                matrix[i][j]=matrix[row-i-1][j];
                matrix[row-i-1][j]=temp;
            }
        }
        //对角线翻转
        for(int i=0;i<row;i++){
            for(int j=0;j<i;j++){
                int temp=matrix[i][j];
                matrix[i][j]=matrix[j][i];
                matrix[j][i]=temp;
            }
        }
        
    }
}

2.复杂度分析

时间复杂度:O(n^2) while(n/2)+for循环+4次while循环的时间损耗

空间复杂度:O(1)  原地转置的空间损耗

Leetcode 240. 搜索二维矩阵 II【中等】

题意理解:

        这个矩阵是有顺序的,左到右升序,上到下升序

        要求找到执行的元素,找到为true,否则为false

解题思路:

       1.逐个对比:双for循环

       2.由于每行都是升序,可以对于每行进行二分排序

       3.对角线查找:每行都是顺序升序的,每列也是升序的

                从右上角到左下角,比当前值大往左,比当前值小往下

                上下维度控制变大,左右维度控制变小

1.解题【双for循环】

class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int row=matrix.length,col=matrix[0].length;
        for(int i=0;i<row;i++){
            for(int j=0;j<col;j++){
                if(matrix[i][j]==target) return true;
            }
        }
        return false;
    }
}

1.解题:【遍历行二分查】

class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int row=matrix.length,col=matrix[0].length;
        for(int i=0;i<row;i++){
            //对每行进行二分查找
            int low=0,high=col-1;
            while(low<=high){
                int mid=(high-low)/2+low;
                int midNum=matrix[i][mid];
                if(midNum==target) return true;
                else if(midNum>target){
                    high=mid-1;
                }else{
                    low=mid+1;
                }
            }
        }
        return false;
    }
}

1.解题:【对角线查找】

class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int row=matrix.length,col=matrix[0].length;
        int i=0,j=col-1;
        //从右上角往左下角找,==返回>往左,<往下
        while(x<row&&y>=0){
            if(matrix[i][j]==target){
                return true;
            }else if(matrix[i][j]>target){
                j--;
            }else if(matrix[i][j]<target){
                i++;
            }
        }
        return false;
    }
}

2.复杂度分析

思路一:

时间复杂度:O(n^2) 双for的时间损耗

空间复杂度:O(1) 变量的空间损耗

思路二:

时间复杂度:O(nlogn) for+二分的时间损耗

空间复杂度:O(1) 变量的空间损耗

思路一:

时间复杂度:O(n) 双for的时间损耗

空间复杂度:O(1) 变量的空间损耗

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

机器人系统开发ros2-基础实践02-自定义一个机器人动作aciton服务端和客户端(c++ 实现)

aciton 是 ROS 中异步通信的一种形式。 操作客户端向操作服务器发送目标请求。 动作服务器将目标反馈和结果发送给动作客户端。 先决条件&#xff1a; 将需要上一个 教程创建操作action_tutorials_interfaces中定义的包和接口。Fibonacci.action 步骤1&#xff1a; 1.1 创建…

ComfyUI学习旅程

一、模型文件&#xff08;Checkpoint&#xff09; 首先它很大&#xff0c;这些文件是你从huggingface或者civitai下载而来的&#xff0c; 所以这些大文件如 .ckpt 或 .safetensors &#xff0c;实际上包含了什么内容呢&#xff1f; 它包含了包含了三种不同模型的权重&#x…

用wps自带工具给图片做标注

在wps中&#xff0c;选中wps中的图片&#xff0c;右键选择【编辑】进入图片编辑器&#xff0c;在选项卡面板右侧选择【标注】工具&#xff0c;再选择【添加文本】工具&#xff0c;即可直接在图片上输入文字&#xff0c;标注完成后选择【覆盖原图】就完成标注任务。

【计算机网络】网络模型

OSI七层网络模型 七层模型如图所示 每层的概念和功能 物理层 职责&#xff1a;将数据以比特为单位&#xff0c;通过不同的传输介质将数据传输出去。 主要协议&#xff1a;物理媒介相关的协议&#xff0c;如RS232&#xff0c;V.35&#xff0c;以太网等。 数据链路层 职责&…

嵌入式Linux driver开发实操(二十三):ASOC

ASoC的结构及嵌入到Linux音频框架 ALSA片上系统(ASoC)层的总体项目目标是为嵌入式片上系统处理器(如pxa2xx、au1x00、iMX等)和便携式音频编解码器提供更好的ALSA支持。在ASoC子系统之前,内核中对SoC音频有一些支持,但它有一些局限性: ->编解码器驱动程序通常与底层So…

搜维尔科技提供电影和动画的动作捕捉解决方案

电影和动画&#xff0c;实时发现讲故事的本质 讲故事的技巧已经发展到给导演比以往更多的控制力和灵活性。从实时预可视化镜头&#xff0c;到将实时镜头与直接流入您选择的工具的同步数据进行合成。动作捕捉消除了计划中的猜测&#xff0c;使不可能成为可能。 特色解决方案-行…

学习Rust的第17天:Traits

Rust traits&#xff0c;包括自定义trait声明&#xff0c;trait边界&#xff0c;实现trait的返回类型&#xff0c;条件方法实现和blanket实现。Rust的多态性严重依赖于traits&#xff0c;这允许基于trait的分派和泛型编程。掌握traits使开发人员能够创建灵活的、可维护的代码&a…

springcloud Ribbion 实战

一、Ribbon单独使用&#xff0c;配置自动重试&#xff0c;实现负载均衡和高可用 1.spring-cloud-starter-netflix-ribbon 包引入 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-ribbon</art…

20240425,模板

感觉比学C那会好了点&#xff0c;不怎么出现照着抄但是就是不能跑的情况&#xff0c;哭死&#xff0c;但是学的顺又不复习&#xff0c;第二天跟没学一样&#xff0c;笑死&#xff0c;要是能给我开个过目不忘的挂&#xff0c;爽的不要不要的 呵呵呵蠢女人&#xff0c;别忘了你C的…

服装厂生产ERP有哪些功能

在当今竞争激烈的服装行业中&#xff0c;企业如何在保证产品质量的同时提高生产效率和市场响应速度?答案在于智能化的生产管理。ERP(企业资源计划)系统作为现代企业管理的核心工具&#xff0c;对于服装厂而言&#xff0c;它的功能不仅需要全面&#xff0c;更要针对性强、操作简…

Python浅谈清朝秋海棠叶版图

1、清朝疆域概述&#xff1a; 清朝是我国最后一个封建王朝&#xff0c;其始于1616年建州女真部努尔哈赤建立后金&#xff0c;此后统一女真各部、东北地区。后又降服漠南蒙古&#xff0c;1644年入关打败农民起义军、灭南明&#xff0c;削三藩&#xff0c;复台湾。后又收外蒙&am…

展馆设计中必不可少的场景

1、一般场景展营造 一般场景是经过对实物进行概括、提炼&#xff0c;进行符号化、审美化的处理后引入展示现场&#xff0c;而并不是将与展品有关联的事物统统罗列其中。 2、复原场景营造 复原场景营造常用于博物馆、纪念馆陈列展示中。运用复原场景就是为了营造历史上曾存在的&…

java中2个List集合值和顺序完全一样,如果判断他们相等

和判断2个字符串是否相等一样&#xff0c;List可以通过equals来判断2个集合是否相等 示例代码如下&#xff1a; 1、相等的示例 2、顺序不一致 3、值不一致

简单使用优雅的程序计数器-StopWatch

一、引入hutool-core 5.8.18包 二、代码 public static void main(String[] args) throws InterruptedException {StopWatch stopWatch new StopWatch("测试StopWatch");stopWatch.start("任务1");// 任务1花费1000毫秒Thread.sleep(1000);stopWatch.st…

Python入门与进阶

基础语法语句 在线python代码运行网址 &#xff08;推荐使用python3网址&#xff09; 基础语法&输入输出 python等号赋值 赋值类型描述示例基本赋值使用等号&#xff08;&#xff09;进行赋值。x10同一个值给多个变量可以使用一个值来赋值给多个变量。xyz10多重赋值可以…

Bentley二次开发教程27-交互窗口-界面开发方法

界面设计概述 引言 在我们掌握了交互式工具的使用方法后&#xff0c;在使用过程中会发现&#xff1a;虽然工具中拥有多种交互的手段&#xff0c;但仅凭工具中鼠标&#xff0c;特殊按键与信息提示等交互方法&#xff0c;没有办法同时对多个信息进行展示&#xff0c;也不够直观…

Redis底层数据结构之IntSet

目录 一、概述二、IntSet结构三、自动升级 redis底层数据结构已完结&#x1f44f;&#x1f44f;&#x1f44f;&#xff1a; ☑️redis底层数据结构之SDS☑️redis底层数据结构之ziplist☑️redis底层数据结构之quicklist☑️redis底层数据结构之Dict☑️redis底层数据结构之Int…

java开发之路——用户管理中心_简单初始化

用户管理中心_简单初始化 (一) 初始化项目1. 使用 Ant Design Pro(现成的管理系统) 进行前端初始化2. 后端初始化三种初始化java项目 (二) 遇到的问题【问题1】Ant design pro页面打不开&#xff0c;一直在budiling控制台出现错误error-./src/components/index.ts【问题2】初始…

ROS python实现乌龟跟随

产生两只乌龟&#xff0c;中间的乌龟(A) 和 左下乌龟(B), B 会自动运行至A的位置&#xff0c;并且键盘控制时&#xff0c;只是控制 A 的运动&#xff0c;但是 B 可以跟随 A 运行 乌龟跟随实现的核心&#xff0c;是乌龟A和B都要发布相对世界坐标系的坐标信息&#xff0c;然后&am…

按钮获取验证码倒计时60秒

把倒计时存在缓存里刷新页面依旧是接着倒计时 <el-buttonsize"large"class"btnStyle":class"btnStyleClass":style"buttonStyle":disabled"countdownActive"click"handleClick">{{ buttonText }}</el-b…