【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;
};
相关推荐
橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——翻转对
算法·排序算法·结构与算法
叠叠乐1 小时前
robot_state_publisher 参数
java·前端·算法
hweiyu001 小时前
排序算法:冒泡排序
算法·排序算法
brave and determined1 小时前
CANN训练营 学习(day9)昇腾AscendC算子开发实战:从零到性能冠军
人工智能·算法·机器学习·ai·开发环境·算子开发·昇腾ai
Dave.B2 小时前
用【vtk3DLinearGridCrinkleExtractor】快速提取3D网格相交面
算法·3d·vtk
一起养小猫2 小时前
LeetCode100天Day1-字符串匹配与Z字形变换
java·leetcode
yaoh.wang2 小时前
力扣(LeetCode) 1: 两数之和 - 解法思路
python·程序人生·算法·leetcode·面试·跳槽·哈希算法
Code Slacker2 小时前
LeetCode Hot100 —— 滑动窗口(面试纯背版)(四)
数据结构·c++·算法·leetcode
brave and determined2 小时前
CANN训练营 学习(day8)昇腾大模型推理调优实战指南
人工智能·算法·机器学习·ai实战·昇腾ai·ai推理·实战记录
总爱写点小BUG3 小时前
打印不同的三角形(C语言)
java·c语言·算法