【Leetcode】【Medium】Search a 2D Matrix

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

 

  • Integers in each row are sorted from left to right.
  • The first integer of each row is greater than the last integer of the previous row.

 

For example,

Consider the following matrix:

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

Given target = 3, return true.

 

解题思路:

在有序队列中寻找目标值,典型的二分搜索应用。

可以有两种思路:(1)使用两次二分搜索,先二分搜索列,确定列之后再二分搜索行;(2)将所有元素看成一列有序数列,每个元素的下标是 row*n + col,这样只需使用一次二分搜索;

虽然第二种思路只使用一次二分搜索,代码简介,但是使用第一种思路更好:

1、方法2需要过多的“/”和“%”运算,大大降低了性能;

2、方法2对比方法1,时间复杂度没有提高;

3、由于所有元素标注为0~m*n,相比方法1先在n中二分搜索,再在m中二分搜索,方法2的做法更可能导致整数越界;

因此,选择使用方法1.

代码:

 1 class Solution {
 2 public:
 3     bool searchMatrix(vector<vector<int>>& matrix, int target) {
 4         int first = 0;
 5         int last = matrix.size() - 1;
 6         while (first < last) {
 7             int mid = (first + last) / 2 + 1;
 8             if (matrix[mid][0] > target)
 9                 last = mid - 1;
10             else 
11                 first = mid;
12         }
13         
14         if (matrix[first][0] > target)
15             return false;
16         
17         int row = first;
18         first = 0;
19         last = matrix[row].size() - 1;
20         while (first < last) {
21             int mid = (first + last) / 2;
22             if (matrix[row][mid] > target)
23                 last = mid;
24             else if (matrix[row][mid] == target)
25                 return true;
26             else 
27                 first = mid + 1;
28         }
29         
30         return (matrix[row][first] == target);
31     }
32 };

 

posted @ 2015-04-07 00:08  胡潇  阅读(172)  评论(0编辑  收藏  举报