题目来源 :https://leetcode-cn.com/
搜索二维矩阵II
题目描述:
编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性:
- 每行的元素从左到右升序排列。
- 每列的元素从上到下升序排列。
示例 1:
输入: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
示例 2:
输入: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 = 20
输出:false
提示:
- m == matrix.length
- n == matrix[i].length
- 1 <= n, m <= 300
- -10^9 <= matix[i][j] <= 10^9
- 每行的所有元素从左到右升序排列
- 每列的所有元素从上到下升序排列
- -10^9<= target <= 10^9
分析:
在矩阵 matrix中,每行每行的元素从左到右升序排列且每列的元素从上到下升序排列;
所以从右上角或者左下角开始查找
- 若当前矩阵的元素值 == target,则直接返回 true。
- 若当前矩阵的元素值 > target,则向上移动一行列不变,即 matrix[i][j] 变为 matrix[i - 1][j],继续进行比较。
- 若当前矩阵的元素值 < target,则向右移动一列行不变,即 matrix[i][j] 变为 matrix[i][j + 1],继续进行比较。
代码实现:
class Solution {
public boolean searchMatrix(int[][] matrix, int target) {
int m = matrix.length-1;
int n = 0;
while (m >= 0 && n < matrix[0].length) {
if (matrix[m][n] == target) {
return true;
} else if (matrix[m][n] >target) {
m--;
} else {
n++;
}
}
return false;
}
}