IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> LeetCode 74 搜索二维矩阵 -> 正文阅读

[数据结构与算法]LeetCode 74 搜索二维矩阵

https://leetcode-cn.com/problems/search-a-2d-matrix/https://leetcode-cn.com/problems/search-a-2d-matrix/icon-default.png?t=L9C2https://leetcode-cn.com/problems/search-a-2d-matrix/

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

每行中的整数从左到右按升序排列。
每行的第一个整数大于前一行的最后一个整数。
?

示例 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

这是一道二分的标准练习题,那么废话不多说直接上代码。

class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
       int upp=0,downp=matrix.size()-1,midd;
       while(upp<=downp){
           midd=upp+(downp-upp)/2;
           if(matrix[midd][0]==target){
               return true;
           }
           else if(matrix[midd][0]>target){
               downp=midd-1;
           }
           else{
               if(matrix[midd][matrix[midd].size()-1]>target){//找到了行
                    //那就再对这个行使用炎拳(划掉),二分吧
                    int leftp=0,rightp=matrix[midd].size()-1,midp;
                    while(leftp<=rightp){
                        midp=leftp+(rightp-leftp)/2;
                        if(matrix[midd][midp]==target){
                            return true;
                        }
                        else if(matrix[midd][midp]>target){
                            rightp=midp-1;
                        }
                        else{
                            leftp=midp+1;
                        }
                    }
                    return false;
               }
               else if(matrix[midd][matrix[midd].size()-1]==target){
                   return true;
               }
               else{
                   upp=midd+1;
               }
           }
       }
       return false;
    }
};

简单讲解一下我的思路,首先我们看图得知是从上到下,从左到右不断增大的矩阵,那么就先找到符合我们要求的那一行,我们不断把每行的首数字和Target进行比较。(使用二分法)

稍微记录一下二分法中的小知识点:

mid值的计算式优先使用leftpoint+(rightpoint-leftpoint)/2而不是(leftpoint+rightpoint)/2,因为前者数值溢出的可能性更小,至于两者等价的原因可以用简单的数学式来推导记录

(leftpoint+rightpoint)/2=leftpoint/2+rightpoint/2=leftpoint-leftpoint/2+rightpoint/2

=leftpoint+(rightpoint-leftpoint)/2? 这样就比较易于记忆。

行首数字和Target比较的时候,如果大于Target,则不论后面的还是下面的都肯定大于Target,我们直接取将二分范围上调;如果是小于Target,我们在把Target和行末数字比较,来判断目标是在该行,还是在下面的范围。

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-10-19 12:08:35  更:2021-10-19 12:09:15 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 19:03:45-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码