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

74. 搜索二维矩阵

题目来源:

        LeetCode题目:74. 搜索二维矩阵 - 力扣(LeetCode)

解题思路:

        两次二分。第一次二分寻找第一列中小于等于target的最大值,第二次 在该行中找到小于等于target的最大值,最后判断是否存在该值及该值是否是 target。

解题代码:

#python3
class Solution:def getIndex(matrix:List[int],target:int)->int:left=0right=len(matrix)-1while(left<right):mid=(left+right)//2+1if matrix[mid]==target:return midelif matrix[mid]<target:left=midelse:right=mid-1return leftdef searchMatrix(self, matrix: List[List[int]], target: int) -> bool:n0=[]for i in range(len(matrix)):n0.append(matrix[i][0])row=Solution.getIndex(n0,target)if row<0 or  row>=len(matrix):return Falsecolumn=Solution.getIndex(matrix[row],target)if column<0 or column>=len(matrix[0]):return Falsereturn matrix[row][column]==target
 

总结:

        官方题解给出了两种解法。第一个是两次二分。第二个是一次二分,讲二维数组拼接为一维数组后再进行二分查找。


http://www.xdnf.cn/news/612217.html

相关文章:

  • 论文Review 地面分割 GroundGrid
  • 方案精读:92页银行数据管控体系设计方案【附全文阅读】
  • Nginx中root与alias的区别及用法
  • TCP 三次握手,第一次握手报文丢失会发生什么?
  • 中国经济的结构性困境与制度性瓶颈:关键卡点深度解析
  • 信号与系统06-系统建模与AI融合
  • JVM—Java对象
  • PLC 数据采集网关 (三格电子)
  • 如何选择服务器机房托管服务?
  • 主类网络和无类网络,什么是主类网络边界
  • bi软件是什么?bi软件是做什么用的?
  • 【PINN】DeepXDE学习训练营(32)——pinn_forward-fractional_diffusion_1d.py
  • YOLOv11改进 | Conv/卷积篇 | 2024 ECCV最新大感受野的小波卷积WTConv助力YOLOv11有效涨点
  • docker镜像操作
  • 《深度揭秘:解锁智能体大模型自我知识盲区探测》
  • 若依 Plus 自定义字典的使用
  • 自动生成md文件以及config.mjs文件-vitepress
  • Flink基于Yarn多种启动方式详解
  • C++之fmt库介绍和使用(3)
  • CARIS HIPS and SIPS 12.1是专业的多波束水深数据和声呐图像处理软件
  • Graph RAG应用实战
  • socc 19 echash论文部分解读
  • 深度学习优化器相关问题
  • yolov5 安卓运行
  • Docker部署Zookeeper集群
  • C++学习之打车软件—JNI终端编程业务④https协议session开发
  • Open CASCADE学习|非线性方程组求解技术详解
  • 公司内网本地的SVN没有公网IP地址,在家外网也能远程访问SVN服务!
  • postgresql 的优劣势比较
  • 多模态理解大模型高性能优化丨前沿多模态模型开发与应用实战第七期