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.
思路:用两次二分查找,先对行查找再对列查找
class Solution {
public:
bool searchMatrix(vector<vector<int>>& matrix, int target) {
int left = 0;
int right = matrix.size()-1;
if(left != right)
{
while(left<=right)
{
int middle = left + (right-left)/2;
if(matrix[middle][0] < target)
{
left = middle+1;
}
else if(matrix[middle][0] > target)
{
right = middle-1;
}
else
{
return true;
}
}
}
if(right == -1)
{
return false;
}
else
{
int row = right;
int left = 0;
int right = matrix[row].size()-1;
while(left<=right)
{
int middle = left + (right-left)/2;
if(matrix[row][middle] < target)
{
left = middle+1;
}
else if(matrix[row][middle] > target)
{
right = middle-1;
}
else
{
return true;
}
}
return false;
}
}
};
74.Search a 2D Matrix
最新推荐文章于 2025-05-19 23:44:29 发布