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

LeetCode 刷题 [C++] 第240题.搜索二维矩阵 II

题目描述

编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性:

每行的元素从左到右升序排列。
每列的元素从上到下升序排列。

在这里插入图片描述

题目分析

  1. 通过分析矩阵的特点发现,其左下角和右上角可以看作一个“二叉搜索树的根节点”,一侧分支元素更小,另一侧分支元素更大;
  2. 因此,可以通过对比根节点与target的大小,动态更新根节点(调整矩阵的下和左边界或者上/右边界),来找出target.
  3. 以左下角元素为“根节点”为例进行分析:
    如果左下角元素大于target,则target一定在左下角元素所在行的上方,此时,更新矩阵的下边界;
    如果左下角元素小于target,则target一定在该元素所在列的右方,此时,更新矩阵的左边界;
    当左下角元素等于target时,找到目标值,返回true;
    当左下角元素的行索引或者列索引越界时,表示没有找到目标,返回false。

Code

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

相关文章:

  • HP笔记本电脑如何恢复出厂设置?这里提供几种方法
  • Elasticsearch:了解人工智能搜索算法
  • (HAL)STM32F103C6T8——软件模拟I2C驱动0.96寸OLED屏幕
  • 分享便携式血氧仪单片机方案
  • 【Java设计模式】四、适配器模式
  • RV32/64 特权架构 - 特权模式与指令
  • 多微服务合并为一个服务
  • Springboot企业级开发--开发入门01
  • bash和sh和./的区别
  • LeetCode 3:寻找最长不含重复字符的子串长度
  • 【自然语言处理四-从矩阵操作角度看 自注意self attention】
  • Unity脚本,串行端口的握手协议(流控制)
  • 2023 re:Invent 用 Amazon Q 打造你的知识库
  • ChatGPT 国内快速上手指南
  • Docker 常用操作命令备忘
  • BUU [CISCN2019 华东南赛区]Web4
  • 【卷积神经网络中用1*1 卷积有什么作用或者好处呢?】
  • 分布式系统概念及其应用
  • 数据报文转换
  • Python爬虫-付费代理推荐和使用
  • kubectl使用及源码阅读
  • C++面试宝典第32题:零钱兑换
  • pyspark分布式部署随机森林算法
  • 【Python笔记-设计模式】中介者模式
  • 大语言模型构建的主要四个阶段(各阶段使用的算法、数据、难点以及实践经验)
  • [云原生] 二进制安装K8S(中)部署网络插件和DNS
  • 云端技术驾驭DAY13——Pod污点、容忍策略、Pod优先级与抢占、容器安全
  • 掌握Docker:让你的应用轻松部署和管理
  • 5G-A,未来已来
  • 智慧公厕让社区生活更美好