【LeetCode热题100(62/100)】搜索二维矩阵

题目地址: 链接

思路: 双重二分(横轴和纵轴)

js 复制代码
/**
 * @param {number[][]} matrix
 * @param {number} target
 * @return {boolean}
 */
var searchMatrix = function(matrix, target) {
    let [n, m] = [matrix.length, matrix[0].length];
    
    let [l1, r1] = [0, n];
    while(l1 < r1) {
        let mid = (l1 + r1) >> 1;
        if( matrix[mid][m - 1] >= target ) r1 = mid;
        else l1 = mid + 1;
    }
    if(l1 >= n) return false;
    
    let [l2, r2] = [0, m];
    while(l2 < r2) {
        let mid = (l2 + r2) >> 1;
        console.log(l1, mid);
        if(matrix[l1][mid] >= target) r2 = mid;
        else l2 = mid + 1;
    }

    return matrix[l1][l2] == target ? true : false;
};
相关推荐
Swift社区6 分钟前
LeetCode 432 - 全 O(1) 的数据结构
数据结构·算法·leetcode
逝玄7 分钟前
关于图灵停机问题不可判定性证明
算法·计算机科学
低客的黑调18 分钟前
为你的项目选择一个适合的[垃圾收集器]
java·jvm·算法
芬加达31 分钟前
leetcode34
java·数据结构·算法
资深web全栈开发1 小时前
LeetCode 1015. 可被 K 整除的最小整数 - 数学推导与鸽巢原理
算法·leetcode·职场和发展
leoufung1 小时前
链表题目讲解 —— 删除链表的倒数第 n 个节点(LeetCode 19)
数据结构·leetcode·链表
dragoooon341 小时前
[优选算法专题八.分治-归并 ——NO.46~48 归并排序 、数组中的逆序对、计算右侧小于当前元素的个数]
数据结构·算法·排序算法·分治
CoderYanger1 小时前
优选算法-队列+宽搜(BFS):72.二叉树的最大宽度
java·开发语言·算法·leetcode·职场和发展·宽度优先·1024程序员节
招摇的一半月亮1 小时前
P2242 公路维修问题
数据结构·c++·算法