- 一、题目
- 二、解题思路
- 1.直接查找
- 2.二分查找
- 三、Java代码
利用for 循环嵌套的形式直接遍历整个矩阵来寻找目标值。
2.二分查找矩阵中的每一行元素都以单调递增的形式有序排列。因此可对每行进行二分查找,寻找目标值。
三、Java代码1.直接查找
class Solution {
public boolean searchMatrix(int[][] matrix, int target) {
for(int[] row : matrix){
for(int i : row){
if(i==target)
return true;
}
}
return false;
}
}
2.二分查找
class Solution {
public boolean searchMatrix(int[][] matrix, int target) {
for(int[] row : matrix){ //将矩阵每一行进行二分查找
int result=search(row,target);
if(result>=0){
return true;
}
}
return false;
}
public int search(int[] rows,int target){ //二分查找的过程
int left=0;
int right=rows.length-1;
while(left<=right){
int middle=left+(right-left)/2;
int row=rows[middle];
if(row==target){
return middle;
}
else if(row>target){
right=middle-1;
}
else
left=middle+1;
}
return -1;
}
}
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/search-a-2d-matrix-ii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。



