博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode-74-搜索二维矩阵
阅读量:5811 次
发布时间:2019-06-18

本文共 1372 字,大约阅读时间需要 4 分钟。

题目描述:

 
编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值。该矩阵具有如下特性:
  • 每行中的整数从左到右按升序排列。
  • 每行的第一个整数大于前一行的最后一个整数。

示例 1:

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

示例 2:

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

 

要完成的函数:

bool searchMatrix(vector<vector<int>>& matrix, int target) 

 

说明:

1、这道题给定一个m行n列的矩阵,要求编写一个高效的算法来判断矩阵中是否含有target这个元素。

如果存在,返回true,否则返回false。

2、这道题其实就是二分法在矩阵上的应用,整个矩阵是升序的。

我们先用二分法确定target可能会在哪一行,接着再用二分法确定target在哪一列,或者不存在。

代码如下:(附详解)

bool searchMatrix(vector
>& matrix, int target) { if(matrix.size()==0||matrix[0].size()==0)return false;//[]或者[[]]的边界条件 int hang=matrix.size(),lie=matrix[0].size(),left=0,right=hang-1,med,t; while(left<=right)//二分法判断target在哪一行 { med=(left+right)/2; if(target
matrix[med][lie-1]) left=med+1; else//找到元素在med这一行了 { t=med; left=0; right=lie-1; while(left<=right)//用二分法找到target在哪一列 { med=(left+right)/2; if(matrix[t][med]==target)//找到了返回true return true; else if(target

上述代码实测8ms,beats 97.83% of cpp submissions。

转载于:https://www.cnblogs.com/chenjx85/p/9492517.html

你可能感兴趣的文章
Online Patching--EBS R12.2最大的改进
查看>>
Binary Search Tree Iterator leetcode
查看>>
Oracle性能优化--DBMS_PROFILER
查看>>
关闭Jquery Ajax 缓存
查看>>
uva-317-找规律
查看>>
Event事件的兼容性(转)
查看>>
我的2014-相对奢侈的生活
查看>>
zoj 2412 dfs 求连通分量的个数
查看>>
【转】inittab文件
查看>>
[ThinkPHP]打开页面追踪调试
查看>>
Java设计模式
查看>>
Entity Framework 实体框架的形成之旅--Code First模式中使用 Fluent API 配置(6)
查看>>
用Swagger生成接口文档
查看>>
一文读懂 AOP | 你想要的最全面 AOP 方法探讨
查看>>
搭建JEESZ分布式架构1--CentOs下安装jdk7(环境准备)
查看>>
数据更新| Qtum 量子链全球大使招募计划
查看>>
分布式锁的解决方案(二)
查看>>
如何写出一个好的单例模式
查看>>
类的设计-使可变性最小
查看>>
三、Android性能优化之常见的内存泄漏分析
查看>>