力扣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++代码实现

cpp 复制代码
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;
    }
};
相关推荐
焦耳加热3 小时前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn3 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6063 小时前
常用排序算法核心知识点梳理
算法·排序
蒋星熠6 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油6 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream6 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
王璐WL6 小时前
【c++】c++第一课:命名空间
数据结构·c++·算法
空白到白7 小时前
机器学习-聚类
人工智能·算法·机器学习·聚类
索迪迈科技7 小时前
java后端工程师进修ing(研一版 || day40)
java·开发语言·学习·算法
zzzsde7 小时前
【数据结构】队列
数据结构·算法