当前位置: 首页 > article >正文

力扣hot100——搜索二维矩阵

题目链接:搜索二维矩阵

虽然本题使用二分法,但二分的写法有很多种,所以在判断 target 大小与有序部分的关系的时候可能会出现细节上的差别。

1、 本题则是与常用代码不同的是:

else if(target<matrix[midRow][columnR])
{
rowH=midRow+1; //本题要改为rowH=midRow,
}
else{
rowL=midRow+1;
}

因为当target<matrix[midRow][columnR]时,target是小于midRow这一行的最右侧的最大元素,而这一行的其他比最右侧元素小的元素与target的关系未知。所以,应该rowH=midRow,而不是rowH=midRow+1。这是为了防止target在矩阵中存在,但是没有搜索到。
2、另一个不同的地方就是二分法的终止条件要从while(l<=r)改为while(l<r)。这是为了防止l或者r越上界或者下界。

c++代码实现

class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int columnL=0,columnR=matrix[0].size()-1;
        int rowL=0, rowH=matrix.size()-1;
        if(columnR==0 && rowH==0)
        {
            if(matrix[0][0]==target)
            {
                return true;
            }
            else{
                return false;
            }
        }
        while (rowL<rowH)
        {
            int midRow = (rowL+rowH)/2;
            if(target == matrix[midRow][columnR])
            {
                return true;
            }
            else if(target<matrix[midRow][columnR])
            {
                rowH=midRow;
            }
            else{
                rowL=midRow+1;
            }
        }
        if(matrix[rowL][columnL]==target)
        {
            return true;
        }
        
        //处理行:rowL行
        while(columnL<columnR)
        {
            int midColumn=(columnL+columnR)/2;
            if(target==matrix[rowL][midColumn])
            {
                return true;
            }
            else if(target<=matrix[rowL][midColumn]){
                columnR=midColumn;
            }
            else{
                columnL=midColumn+1;
            }
        }  
        if(matrix[rowL][columnL]==target)
        {
            return true;
        }
        return false;
    }
};

原文地址:https://blog.csdn.net/ml29895063/article/details/146588581
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.kler.cn/a/613473.html

相关文章:

  • Android读写权限分析
  • MFC(1)-odbc-ado-调用mysql,sqlserver
  • AI大模型从0到1记录学习 day08
  • Go 语言标准库中encoding/xml模块详细功能介绍与示例
  • 【QT5 多线程示例】异步编程
  • Java 实现将Word 转换成markdown
  • fyrox 2D和3D游戏的制作
  • uvm factory
  • android studio调试aosp手机userdebug版本无法查看局部变量和参数问题如何解决?
  • 设置github 代理
  • 解决PLC通信会断然后报错的问题
  • 相对位置2d矩阵和kron运算的思考
  • MFC中的窗口线程安全性与CWnd类
  • 从 YOLO11 模型格式导出到TF.js 模型格式 ,环境爬坑,依赖关系已经贴出来了
  • 智慧养老时代:老年人慢性病预防与生活方式优化
  • 【今日EDA行业分析】2025年3月28日
  • 基于扩散模型的光照编辑新突破:IC-Light方法解析与优化
  • DeepSeek大模型应用开发新模式
  • 智能舵机:AI融合下的自动化新纪元
  • ADZS-ICE-2000和AD-ICE2000仿真器在线升级固件