当前位置: 首页 > article >正文

【力扣】240.搜索二维矩阵 II

题目

我的代码

class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        for(int i=0;i<matrix.size();i++){
            for(int j=0;j<matrix[0].size();j++){
                if(target==matrix[i][j]){
                    return true;
                }else if(target<matrix[i][j]){
                    break;
                }
            }
            if(matrix[i][0]>target){
                break;
            }
        }

        return false;
    }
};

Z字搜索法

我的解法实在招笑,自以为优化了,其实优化了个寂寞,一看答案惊为天人。

思路:

我们可以从矩阵 matrix 的右上角 (0,n−1) 进行搜索。在每一步的搜索过程中,如果我们位于位置 (x,y),那么我们希望在以 matrix 的左下角为左下角、以 (x,y) 为右上角的矩阵中进行搜索,即行的范围为 [x,m−1],列的范围为 [0,y]:

    如果 matrix[x,y]=target,说明搜索完成;

    如果 matrix[x,y]>target,由于每一列的元素都是升序排列的,那么在当前的搜索矩阵中,所有位于第 y 列的元素都是严格大于 target 的,因此我们可以将它们全部忽略,即将 y 减少 1;

    如果 matrix[x,y]<target,由于每一行的元素都是升序排列的,那么在当前的搜索矩阵中,所有位于第 x 行的元素都是严格小于 target 的,因此我们可以将它们全部忽略,即将 x 增加 1。

在搜索的过程中,如果我们超出了矩阵的边界,那么说明矩阵中不存在 target。

代码与AC截图

class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m=0;
        int n=matrix[0].size()-1;

        while(m<matrix.size()&&n>=0){
            if(target==matrix[m][n]){
                return true;
            }else if(target<matrix[m][n]){
                n--;
            }else{
                m++;
            }
        }

        return false;
    }
};


http://www.kler.cn/a/533954.html

相关文章:

  • 《redis4.0 通信模块源码分析(一)》
  • 如何开发一个大语言模型,开发流程及需要的专业知识
  • 熟练掌握Http协议
  • 渗透笔记2
  • 谈谈你所了解的AR技术吧!
  • 蓝桥杯C语言组:暴力破解
  • 4 前端前置技术(上):AJAX技术、Axios技术(前端发送请求)
  • idea分析sql性能
  • win32汇编环境,对话框程序中自定义工具栏的使用示例
  • neo4j-在Linux中安装neo4j
  • 【华为OD-E卷 - 115 数组组成的最小数字 100分(python、java、c++、js、c)】
  • C# Action和 Func的用法
  • [操作系统] 进程终止
  • 大模型 Llama 微调如何适配中文_词表扩展
  • 如何开发一个大语言模型,开发流程及需要的专业知识
  • 【数学】矩阵、向量(内含矩阵乘法C++)
  • Ubuntu22.04如何设置linux-lowlatency核心
  • 扩增子分析|零模型2——基于βNTI的微生物随机性和确定性装配过程(箱线图和柱状图R中实现)
  • Ubuntu 下 nginx-1.24.0 源码分析 - ngx_sprintf_num 函数
  • 2024年Web前端最新Java进阶(五十五)-Java Lambda表达式入门_eclipse lambda(1),面试必备
  • 高压GaN(氮化镓)器件在工业和汽车应用存在的致命弱点
  • git 设置分支跟踪
  • Nginx通过设置自定义标记识别代理调用
  • VMware Win10下载安装教程(超详细)
  • 《手札·开源篇》基于开源Odoo软件与Deepseek的智能企业管理系统集成方案
  • R语言 | 使用 ComplexHeatmap 绘制热图,分区并给对角线分区加黑边框