学习记录:js算法(三十七): 搜索二维矩阵

server/2024/9/24 13:27:59/

文章目录

    • 搜索二维矩阵
      • 我的思路
      • 网上思路
    • 总结

搜索二维矩阵

给你一个满足下述两条属性的 m x n 整数矩阵:
● 每行中的整数从左到右按非严格递增顺序排列。
● 每行的第一个整数大于前一行的最后一个整数。
给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false

示例 1:
输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 3
输出:true示例 2:
输入:matrix = [[1,3,5,7],[10,11,16,20],[23,30,34,60]], target = 13
输出:false

我的思路
循环,尝试二分法
网上思路
二分法

我的思路

var searchMatrix = function (matrix, target) {if (matrix.length === 0 || matrix[0].length === 0) {return false;}const rows = matrix.length;const cols = matrix[0].length;for (let i = 0; i < rows; i++) {if (target < matrix[i][0]) {return false;}if (target > matrix[i][cols - 1]) {continue;}for (let j = 0; j < cols; j++) {if (matrix[i][j] === target) {return true;}}}return false;
};

讲解
双重循环,主要是以下边界条件进行判断

  1. 如果 target 小于当前行的第一个元素,直接返回 false
  2. 如果 target 大于当前行的最后一个元素,继续检查下一行。

网上思路

var searchMatrix = function(matrix, target) {const m = matrix.length, n = matrix[0].length;let low = 0, high = m * n - 1;while (low <= high) {const mid = Math.floor((high - low) / 2) + low;const x = matrix[Math.floor(mid / n)][mid % n];if (x < target) {low = mid + 1;} else if (x > target) {high = mid - 1;} else {return true;}}return false;
};

讲解
若将矩阵每一行拼接在上一行的末尾,则会得到一个升序数组,我们可以在该数组上二分找到目标元素。
代码实现时,可以二分升序数组的下标,将其映射到原矩阵的行和列上。

  1. 初始化两个指针 lowhighlow 指向矩阵的 起始位置(0)high 指向矩阵的 结束位置(总元素数 - 1)
  2. low 小于或等于 high 时,继续进行查找。
  3. 计算中间位置 mid。这里使用了 (high - low) / 2 来避免直接相加可能导致的溢出。
  4. 将一维索引 mid 转换为二维索引:
    1. 行索引为 Math.floor(mid / n),表示当前元素在矩阵中的行。
    2. 列索引为 mid % n,表示当前元素在矩阵中的列。
    3. 这样就可以通过 x 获取当前中间位置的元素。
  5. 如果当前元素 x 小于 target,则目标值一定在右半部分,因此将 low 更新为 mid + 1
  6. 如果当前元素 x 等于 target,则找到了目标值,返回 true

总结

很实用,正好我自身有项目在使用二维矩阵,明天我来试试


http://www.ppmy.cn/server/121364.html

相关文章

最近的生活

最近的生活&#xff0c;让我先回忆一下子。 第一个&#xff0c;我和室友报名了一个游泳俱乐部&#xff0c;但是实际上是一个豪庭的健身房&#xff0c;我们磨价钱磨了一下午&#xff0c;我还从来没有水里玩过呢&#xff0c;甚至一度觉得我进到水里面&#xff0c;耳朵会进水&…

二刷LeetCode:“51.N皇后 37.解数独”题解心得(简单易懂)

引言&#xff08;初遇噩梦&#xff0c;再遇坦然&#xff09; 在阅读本文之前&#xff0c;建议大家已经接触过回溯算法&#xff0c;并完成回溯相关题目&#xff0c;例如&#xff1a;子集问题、组合问题、排列问题。 子集&#xff1a;子集II、子集 组合&#xff1a;组合、组合总和…

Go语言流程控制

Go语言流程控制 1.IF-ELSE2.Switch-Caseswitch 语句Type Switch 3.select 语句4.循环语句 1.IF-ELSE Go 编程语言中 if 语句的语法如下&#xff1a; if 布尔表达式 {/* 在布尔表达式为 true 时执行 */ }例如&#xff1a; package mainimport "fmt"func main() {va…

展锐平台的手机camera 系统isptool 架构

展锐平台的isptool 主要用于支持展锐各代芯片isp的各效果模块快速tuning和参数生成打包。 具体需要&#xff1a; 一、工具段能在线实时预览到调试sensor经过isp 处理后的图像&#xff0c;也就是各模块的参数在当下实时生效&#xff0c;通过工具能在PC 上在线观看到修改的效果。…

Spring Cloud 教程(一) | 认识Spring Cloud

Spring Cloud Alibaba教程&#xff08;一&#xff09; | 认识Spring Cloud Alibaba 前言一、SpringBoot和SpringCloud区别二、SpringCloud 第一代&#xff08;Spring Cloud Netflix&#xff09;三、SpringCloud 第二代&#xff08;Spring Cloud Alibaba&#xff09; 前言 sp…

Appium独立测试自动化初始化脚本

1、查看环境初始化参数 确保appium已经开起来了&#xff0c;设置ip ,并点击启动 打开夜神模拟器&#xff0c;点击工具--设置 最下面的版本说明&#xff0c;双击进去 版本号这里再去单击。 直到进入到开发者模式。 可能我们不是开发者模式打开的状态&#xff0c;所以软件访问模…

验收测试:从需求到交付的全程把控!

在软件开发过程中&#xff0c;验收测试是一个至关重要的环节。它不仅是对软件质量的把关&#xff0c;也是对整个项目周期的全程把控。从需求分析到最终的软件交付&#xff0c;验收测试都需要严格进行&#xff0c;以确保软件能够符合预期的质量和性能要求。 一、需求分析阶段 在…

express的Router,配置 post 请求方法

在Express中&#xff0c;使用Router对象配置POST请求方法与在主应用上配置POST请求方法非常相似。你首先需要从express模块中引入Router&#xff0c;然后创建一个Router实例。接下来&#xff0c;你可以在这个Router实例上使用.post()方法来定义POST请求的路由处理器。 下面是一…