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

LeetCode—74. 搜索二维矩阵(中等)

仅供个人学习使用

题目描述

给你一个满足下述两条属性的 m x n 整数矩阵:

  • 每行中的整数从左到右按非严格递增顺序排列。

  • 每行的第一个整数大于前一行的最后一个整数。

给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false 。

示例1:

输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
输出:true

示例2:

输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 13
输出:false

题目解析: 

因为矩阵具有单调性,所以可以将问题转化为一维数组的查找问题。具体步骤如下:

  1. 初始化:设置两个指针lowhigh,分别指向矩阵的左上角(0,0)和右下角(m*n-1),其中m是矩阵的行数,n是矩阵的列数。

  2. 二分查找:在lowhigh之间进行二分查找。

    • 计算中间位置mid
    • 根据mid计算出在矩阵中对应的元素x,即matrix[mid / n][mid % n]。这里mid / n计算出中间位置所在的行,mid % n计算出中间位置所在的列。
  3. 比较与调整

    • 如果x小于target,则将low指针移动到mid + 1,因为target一定在mid的右边。
    • 如果x大于target,则将high指针移动到mid - 1,因为target一定在mid的左边。
    • 如果x等于target,则返回true,表示找到了目标值。
  4. 循环结束:如果low超过了high,则表示没有找到目标值,返回false

实现代码:

class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int m = matrix.length,n = matrix[0].length;
        int low = 0,high = m * n -1;
        while(low <= high){
            int mid = (low + high)/2;
            int x = matrix[mid / n][mid % n];
            if(x < target){
                low = mid + 1;
            }else if(x > target){
                high = mid - 1;
            }else return true;
        }
        return false;
    }
}


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

相关文章:

  • 5G学习笔记之随机接入
  • 【Git系列】Git 提交历史分析:深入理解`git log`命令
  • 【问题】webdriver.Chrome()设置参数executable_path报不存在
  • C++多态的实现原理
  • 基于Java Springboot蛋糕订购小程序
  • 【数据结构】二叉搜索树(二叉排序树)
  • 【Go - 什么有序?解密MongoDB bson.D】
  • 用php 处理 xls和xlsx (简单版)
  • 【JavaEE 初阶】⽹络原理 - 初识
  • 组播基础实验
  • FRU文件
  • python7学习笔记-循环、迭代、pass
  • 开源 - Ideal库 - Excel帮助类,TableHelper实现(三)
  • 【随笔】一次JS和python中的MD5加密的记录
  • Filter过滤器的使用
  • 爬虫技术全解析:从入门到精通
  • FPGA芯片全生命周期流程
  • 手机实时提取SIM卡打电话的信令声音-蓝牙电话如何适配eSIM卡的手机
  • vue实现时间倒计时/时间增加组件
  • 基于Vue3+Element Plus 实现多表单校验
  • Oracle 11gR2 Data Guard 搭建 (一主一从)
  • Linux高级文件系统
  • FPGA实现串口升级及MultiBoot(十)串口升级SPI FLASH实现
  • 【C++】getchar() 与 putchar() 的深入解析
  • Transformer?Attention?——Are All You Need!
  • 2个方法教打开把Word文档转换为PDF格式