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

力扣HOT100之二分查找:74. 搜索二维矩阵


这道题直接a了,我们可以参考上一道题:35.搜索插入位置的思路,详情见我的上一篇博客。将每一行的第一个元素当作一个数组中的元素,然后对这个数组进行二分查找,如果直接找到了target,则直接返回true,否则退出循环的时候left指向应当插入的下标位置,举几个例子:
1.当输入为

[[1,3,5,7],[10,11,16,20],[23,30,34,60]]

target3,则退出循环时left指向元素10所在的位置,此时我们应当去上一层(matrix[left - 1])寻找target
2.当输入为

[[1,3,5,7],[10,11,16,20],[23,30,34,60]]

target为61,则退出循环时left的值为3,此时我们应当去上一层(matrix[left - 1],即matrix[2])寻找target
3.当输入为

[[1,3,5,7],[10,11,16,20],[23,30,34,60]]

target为0,则退出循环时left的值为0,此时我们无法去上一层(matrix[-1],会发生溢出)寻找target。所以我们需要判断一下退出二分查找后的left是否大于0,只有大于0才进行进一步的搜索,当遍历完整层都没有找到时,返回false,若找到则直接返回true

class Solution {
public:bool searchMatrix(vector<vector<int>>& matrix, int target) {int left = 0, right = matrix.size();int mid;while(left < right){mid = (left + right) / 2;if(matrix[mid][0] > target)right = mid;else if(matrix[mid][0] < target)left = mid + 1;else return true;            }int i = 0;while(left > 0 && i < matrix[0].size()){if(matrix[left - 1][i] == target)return true;i++;}return false;}
};
http://www.lryc.cn/news/2400670.html

相关文章:

  • 【前端】前后端通信
  • 编程技能:格式化打印04,sprintf
  • C语言基础(11)【函数1】
  • R语言基础| 下载、安装
  • 【hive sql】窗口函数
  • Ubuntu24.04 交叉编译 aarch64 ffmpeg
  • 《AI角色扮演反诈技术解析:原理、架构与核心挑战》
  • 微软的新系统Windows12未来有哪些新特性
  • 树莓派超全系列教程文档--(54)如何使用rsync在计算机之间同步文件夹
  • 华为ICT和AI智能应用
  • ROS2与Unitree机器人集成指南
  • 在虚拟宇宙中低语——进程间通信,Linux命名管道的前世今生
  • Cursor 工具项目构建指南:Java 21 环境下的 Spring Boot Prompt Rules 约束
  • 各个布局的区别以及示例
  • 什么是MVC?
  • STM32的ADC简介
  • Bash shell四则运算
  • (javaSE)Java数组进阶:数组初始化 数组访问 数组中的jvm 空指针异常
  • 力扣刷题Day 70:在排序数组中查找元素的第一个和最后一个位置(34)
  • vue 多端适配之pxtorem
  • 图片压缩工具 | 图片属性详解及读取解析元数据
  • React---day8
  • C# Onnx 动漫人物人脸检测
  • C++内存列传之RAII宇宙:智能指针
  • PVE 虚拟机安装 Ubuntu Server V24 系统 —— 一步一步安装配置基于 Ubuntu Server 的 NodeJS 服务器详细实录1
  • GitHub 趋势日报 (2025年06月03日)
  • 出现dev/nvmeOnip2 contains a file system with errors, check forced 解决方法
  • Vue3.5 企业级管理系统实战(二十二):动态菜单
  • 磨皮功能 C++/C的OpenCV 实现
  • 蓝牙防丢器应用方案