LeetCode 专题 – 二分查找专题
74. 搜索二维矩阵
难度:中等
题目描述
编写一个高效的算法来判断 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
链接:
Solution
class Solution {
public boolean searchMatrix(int[][] matrix, int target) {
if(matrix.length == 0 || matrix[0].length == 0) return false;
// 找到行首元素最后一个小于等于target的行
int low = 0, high = matrix.length - 1;
int row = 0;
while(low <= high){
int mid = low + (high - low) / 2;
if(matrix[mid][0] <= target){
if(mid == matrix.length - 1 || matrix[mid + 1][0] > target){
row = mid;
break;
}else low = mid + 1;
}else high = mid - 1;
}
// 在该行中找到目标值,否则返回false
low = 0;
high = matrix[0].length - 1;
while(low <= high){
int mid = low + (high - low) / 2;
if(matrix[row][mid] > target) high = mid - 1;
else if(matrix[row][mid] < target) low = mid + 1;
else return true;
}
return false;
}
}
此博客聚焦LeetCode二分查找专题,以74题搜索二维矩阵为例。题目要求判断m x n矩阵中是否存在目标值,矩阵每行整数升序排列,且每行首数大于前一行尾数。还给出了题目链接。

1143

被折叠的 条评论
为什么被折叠?



