热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

LeetCode74搜索二维矩阵

目录题目解方法一:暴力搜索方法二:缩小边界范围方法三:将一维坐标转换为二维坐标方法四:2次二分查找题目LeetCode74搜索二维矩阵提示:mmatrix.lengthnmatri

目录



  • 题目



    • 方法一:暴力搜索

    • 方法二:缩小边界范围

    • 方法三:将一维坐标转换为二维坐标

    • 方法四:2次二分查找




题目

LeetCode74 搜索二维矩阵

提示:



  • m == matrix.length

  • n == matrix[i].length

  • 1 <= m, n <= 100

  • -104 <= matrix[i][j], target <= 104



方法一:暴力搜索

遍历查找,O(mn)。

简单,但不是期望考察的算法。

bool searchMatrix1(vector>& matrix, int target) {
bool res = false;
for (auto &row : matrix) {
for (auto e : row) {
if (e == target) res = true;
}
}
return res;
}

方法二:缩小边界范围

从右上角开始,逐渐缩小数据查找范围,O(m+n)。

记坐标(row, col)对应值为M(row, col),有

当M(row, col)
当M(row, col) > target时,边界左移一列;

相等时,说明已成功找到

bool searchMatrix(vector>& matrix, int target) {
if (matrix.size() == 0) return false;
int row = 0, col = matrix[0].size() - 1;
while (row = 0) {
if (matrix[row][col] row++; // 下移一行
else if (matrix[row][col] > target)
col--; // 左移一列
else
return true;
}
return false;
}

方法三:将一维坐标转换为二维坐标

先将一维坐标转换为二维坐标,然后用二分查找,O(mn)。

设矩阵M为m x n二维矩阵,看成一维数组就是M[0..m * n - 1].

设二分法初始位置begin = 0, end = m*n - 1,则mid = (begin + end) / 2。

这样,可以用标准的二分法,在begin~end之间查找target。

bool searchMatrix(vector>& matrix, int target) {
if (matrix.empty() || matrix[0].empty()) return false;
int begin, end;
int n1 = matrix.size(), n2 = matrix[0].size();
begin = 0;
end = n1 * n2 - 1;
while (begin <= end) {
int mid = begin + (end - begin) / 2;
int x = matrix[mid / n2][mid % n2];
if (x == target) return true;
else if (x begin = mid + 1;
else
end = mid - 1;
}
return false;
}

方法四:2次二分查找

第一次,对矩阵第一列进行二分查找,找到最后一个不大于目标值的元素;

第二次,在第一次查到的所在行进行二分查,判断目标值是否存在。

注:upper_bound是在给定范围中,查找大于目标值的第一个元素。返回的是一个迭代器。

bool searchMatrix(vector>& matrix, int target) {
// row对应matrix的matrix[?][0]元素,是第一个大于target的行
auto row = std::upper_bound(matrix.begin(), matrix.end(), target, [](const int b, const vector& a){ // 传入比较子的参数:b 是要查找的目标元素(target),a是martix中的元素(vector)
return b });

if (row == matrix.begin()) return false;
--row; // 此时,row对应matrix的行,是最后一个matrix[?][0]不大于target的行
return std::binary_search(row->begin(), row->end(), target);
}


推荐阅读
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 如何在PHPCMS V9中实现多站点功能并配置独立域名与动态URL
    本文介绍如何在PHPCMS V9中创建和管理多个站点,包括配置独立域名、设置动态URL,并确保各子站能够正常运行。我们将详细讲解从新建站点到最终配置路由的每一步骤。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 离线环境下的Python及其第三方库安装指南
    在项目开发中,有时会遇到电脑只能连接内网或完全无法联网的情况。本文将详细介绍如何在这种环境下安装Python及其所需的第三方库,确保开发工作的顺利进行。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 本文将详细介绍在Windows 7环境下,检查U盘启动盘是否制作成功的多种方法,包括通过BIOS设置和使用模拟启动工具。 ... [详细]
  • 深入理解 H5C3 和 JavaScript 核心问题
    本文详细探讨了 H5C3 和 JavaScript 中的一些核心编程问题,通过实例解析和代码示例,帮助开发者更好地理解和应用这些技术。 ... [详细]
  • 利用存储过程构建年度日历表的详细指南
    本文将介绍如何使用SQL存储过程创建一个完整的年度日历表。通过实例演示,帮助读者掌握存储过程的应用技巧,并提供详细的代码解析和执行步骤。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 近期遇到电脑网络不稳定和游戏时频繁重启的问题,寻求专业建议。网络环境为ADSL调制解调器通过路由器共享给两台电脑使用,怀疑存在ARP攻击或硬件配置问题。希望获得详细的故障排查和解决方案。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 百度服务再次遭遇技术问题,疑似DNS解析故障
    近日晚间,百度多项在线服务出现加载异常,包括移动端搜索在内的多个功能受到影响。初步迹象表明,问题可能与DNS服务器解析有关。 ... [详细]
author-avatar
最低调的鹌鹑
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有