Skip to content

每日LeetCode 151

151

编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值。该矩阵具有如下特性:

class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int result = binarySearch(matrix, target);
        if (result == -1) {
            return false;
        } else {
            return binarySearch(matrix[result], target);
        }
    }

    public int binarySearch(int[][] matrix, int target) {
        int n = matrix.length;
        int left = -1;
        int right = n - 1;
        while (left < right) {
            int mid = left + (right - left + 1) / 2;
            if (matrix[mid][0] <= target) {
                left = mid;
            } else {
                right = mid - 1;
            }
        }
        return left;
    }

    public boolean binarySearch(int[] matrix, int target) {
        int n = matrix.length;
        int left = 0;
        int right = n - 1;
        while (left <= right) {
            int mid = left + (right - left) / 2;
            if (matrix[mid] == target) {
                return true;
            } else if (matrix[mid] < target) {
                left = mid + 1;
            } else {
                right = mid - 1;
            }
        }
        return false;
    }
}