题目:

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

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

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

示例:

现有矩阵 matrix 如下:

[

[1, 4, 7, 11, 15],

[2, 5, 8, 12, 19],

[3, 6, 9, 16, 22],

[10, 13, 14, 17, 24],

[18, 21, 23, 26, 30]

]

给定 target = 5,返回 true。

给定 target = 20,返回 false。


思路:

二分法。

  1. 先获取当前矩阵的最大值和最小值,即左上角的值和右下角的值

    为(x1,y1)和(x2,y2)。当x1 = x2 且 y1 = y2时,说明矩阵为一个点。
  2. 求mid值,即 ( (x1+x2)/2 , (y1+y2)/2 )
  3. 将mid值与target进行比较,来决定接下来取查询那些范围

    · 如果target = mid 说明找到了目标值

    · 如果target < mid,说明以mid为最小值的那块矩阵,不会有target, target在其他范围

    · 如果target > mid,说明以mid为最大值的那块矩阵里,不会有target, target在其他范围里面
  4. 接下来对其他范围进行递归查询

代码:

  1. class Solution {
  2. public boolean searchMatrix(int[][] matrix, int target) {
  3. if (matrix == null || matrix.length < 1 || matrix[0] == null || matrix[0].length < 1) {
  4. return false;
  5. }
  6. return searchMatrix(matrix,target,0,0,matrix.length-1,matrix[0].length-1);
  7. }
  8. //方法
  9. private boolean searchMatrix(int[][] matrix, int target, int x1, int y1, int x2, int y2) {
  10. if(x2 < x1 || y2 < y1){
  11. return false;
  12. }
  13. if(target < matrix[x1][y1] || target > matrix[x2][y2]){//若果小于矩阵最小值,或者大于矩阵最大值,直接返回false。
  14. return false;
  15. }
  16. int mid_x = (x1 + x2) / 2;
  17. int mid_y = (y1 + y2) / 2;
  18. if(target == matrix[mid_x][mid_y]){
  19. return true;
  20. }
  21. if(target < matrix[mid_x][mid_y]){ //target不在第四象限
  22. return (
  23. //查找第二象限
  24. searchMatrix(matrix,target,x1,y1,mid_x-1,mid_y-1) ||
  25. //查找第一象限
  26. searchMatrix(matrix,target,x1,mid_y,mid_x-1,y2) ||
  27. //查找第三象限
  28. searchMatrix(matrix,target,mid_x,y1,x2,mid_y-1)
  29. );
  30. }else { //target不在第二象限
  31. return (
  32. //查找第四象限
  33. searchMatrix(matrix, target,mid_x+1,mid_y+1,x2,y2) ||
  34. //查找第一象限
  35. searchMatrix(matrix,target,x1,mid_y+1,mid_x,y2) ||
  36. //查找第三象限
  37. searchMatrix(matrix,target,mid_x+1,y1,x2,mid_y)
  38. );
  39. }
  40. }
  41. }

但是我看其他人提交的代码,思路是从左下 或者 右上开始遍历。

思路是:

从左下角角标开始查找

如果>target 则向上移动角标

如果<target 则向右移动角标

如果==target 则返回True

如果角标出界还没找到target 则返回False

但是我认为这种不是最优的,比如二维数组只有一行或者一列的话,这就是一次时间复杂度为O(n)的遍历。

代码如下(代码是从右上角开始的)

  1. class Solution {
  2. public boolean searchMatrix(int[][] matrix, int target){
  3. if (matrix.length==0)
  4. return false;
  5. int i = matrix.length-1,j=0;
  6. while(i>=0 && j<matrix[0].length){
  7. if (matrix[i][j] == target)
  8. return true;
  9. else if(matrix[i][j]>target)
  10. i--;
  11. else if(matrix[i][j]<target)
  12. j++;
  13. }
  14. return false;
  15. }
  16. }

leetcode240 搜索二维矩阵 II的更多相关文章

  1. leetcode-240搜索二维矩阵II

    搜索二维矩阵II class Solution: def searchMatrix(self, matrix, target): """ :type matrix: Li ...

  2. [Swift]LeetCode240. 搜索二维矩阵 II | Search a 2D Matrix II

    Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the follo ...

  3. lintcode:搜索二维矩阵II

    题目 搜索二维矩阵 II 写出一个高效的算法来搜索m×n矩阵中的值,返回这个值出现的次数. 这个矩阵具有以下特性: 每行中的整数从左到右是排序的. 每一列的整数从上到下是排序的. 在每一行或每一列中没 ...

  4. LintCode-38.搜索二维矩阵 II

    搜索二维矩阵 II 写出一个高效的算法来搜索m×n矩阵中的值,返回这个值出现的次数. 这个矩阵具有以下特性: 每行中的整数从左到右是排序的. 每一列的整数从上到下是排序的. 在每一行或每一列中没有重复 ...

  5. Leetcode 240.搜索二维矩阵II

    搜索二维矩阵II 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target.该矩阵具有以下特性: 每行的元素从左到右升序排列. 每列的元素从上到下升序排列. 示例: 现有 ...

  6. Leetcode之二分法专题-240. 搜索二维矩阵 II(Search a 2D Matrix II)

    Leetcode之二分法专题-240. 搜索二维矩阵 II(Search a 2D Matrix II) 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target.该矩阵 ...

  7. LeetCode 240. 搜索二维矩阵 II(Search a 2D Matrix II) 37

    240. 搜索二维矩阵 II 240. Search a 2D Matrix II 题目描述 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target.该矩阵具有以下特性 ...

  8. Java实现 LeetCode 240 搜索二维矩阵 II(二)

    240. 搜索二维矩阵 II 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target.该矩阵具有以下特性: 每行的元素从左到右升序排列. 每列的元素从上到下升序排列. ...

  9. 240. 搜索二维矩阵 II

    二维数组搜索 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target.该矩阵具有以下特性: 每行的元素从左到右升序排列. 每列的元素从上到下升序排列. 示例: 现有矩阵 ...

随机推荐

  1. 机器学习之SVM算法

    1.知识点 """ SVM,也称支持向量机:其优化核心为求取点到平面的距离最大化,主要是解决二分类问题 y = wx+b ,且 yi * y(i) >0 恒成立 思 ...

  2. 接入上一篇SSM框架整合示例

    需要创建相应的包与文件夹 Book数据表作为本示例数据 搭建项目开始 首先有bean后 private int id; private String name; private int cnt; 第一 ...

  3. Script Form商业报表程序设计

    Script Form 是SAP所提供的一款强大的报表设设计工具. 一.Script Form主要工具包括如下: 1)Form Painter:格式绘制器,用于格式的设定.TCoce:SE71. 2) ...

  4. linux常用命令(8)cat命令

    cat命令的用途是连接文件或标准输入并打印.这个命令常用来显示文件内容,或者将几个文件连接起来显示,或者从标准输入读取内容并显示,它常与重定向符号配合使用. 1 命令格式:cat [选项] [文件]. ...

  5. C基础知识(14):命令行参数

    命令行参数是使用main()函数参数来处理的,其中,argc是指传入参数的个数,argv[]是一个指针数组,指向传递给程序的每个参数. 应当指出的是,argv[0]存储程序的名称,argv[1]是一个 ...

  6. Winform非UI线程更新UI界面的各种方法小结

    我们知道只有UI线程才能更新UI界面,其他线程访问UI控件被认为是非法的.但是我们在进行异步操作时,经常需要将异步执行的进度报告给用户,让用户知道任务的进度,不至于让用户误认为程序“死掉了”,特别是对 ...

  7. JavaScript(1)——编程真善美

    编程真善美 命名风格: 驼峰命名法 小驼峰法 变量一般用小驼峰法标识.驼峰法的意思是:除第一个单词之外,其他单词首字母大写:camelCase 大驼峰法(即帕斯卡命名法) 相比小驼峰法,大驼峰法把第一 ...

  8. lxml的XPath解析

    BeautifulSoup 可以将lxml作为默认的解析器使用,同样lxml可以单独使用.下面比较这两者之间优缺点: BeautifulSoup和lxml原理不一样,BeautifulSoup是基于D ...

  9. 【Python开发】urllib2.urlopen超时问题

    原帖地址:http://hi.baidu.com/yss1983/item/933fbe45a09c43e01381da06 问题描述:     没有设置timeout参数,结果在网络环境不好的情况下 ...

  10. 【VS开发】设备控制台 (DevCon.exe) 示例

    设备控制台 (DevCon.exe) 示例 本部分提供以下设备控制台 (DevCon.exe) 命令的示例: DevCon HwIDs 示例 1:查找所有硬件 ID 示例 2:使用模式查找硬件 ID ...