74. 搜索二维矩阵 (力扣)

给你一个满足下述两条属性的 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

提示:

  • m == matrix.length
  • n == matrix[i].length
  • 1 <= m, n <= 100
  • -10^4 <= matrix[i][j], target <= 10^4

代码部分:

复制代码
bool searchMatrix(int** matrix, int matrixSize, int* matrixColSize, int target) {
    int m = matrixSize, n = matrixColSize[0];  // 行数,列数
    int left =  0, right = n - 1 ;   // 对符合要求的行,进行二分查找
    int t = 0 ;        // 来记录那一行符合要求,唯一(每行的第一个整数大于前一行的最后一个数)
    if(m == 1 && n == 1 && matrix[left][right] == target){//判断边界,看是否只有一个值
        return true;                                      //一个值,且是要查找的值,返回
    } 
    if(m == 1 && n == 1 && matrix[left][right] != target){
        return false;                                       //一个值,不是要查找的值,返回
    }
    
    for(int i = 0 ; i < m ; i++){   // 确定要查找的行

        if(matrix[i][left] <= target  && matrix[i][right] >= target){
                t = i;
                break;
        }
    }
    int mid;
    while(left <= right){   // 对要查找的行,进行二分
            mid = left + ( right - left ) / 2;
        if(matrix[t][mid] == target){
                return true;
        }
        else if(matrix[t][mid] > target){
            right = mid - 1;
        }
        else{
            left = mid + 1; 
        }
    }
     
    return false;   // 没有返回false
}
相关推荐
czlczl2002092540 分钟前
算法:二叉树的公共祖先
算法
稚辉君.MCA_P8_Java1 小时前
Gemini永久会员 Java动态规划
java·数据结构·leetcode·排序算法·动态规划
小白程序员成长日记2 小时前
2025.11.23 力扣每日一题
算法·leetcode·职场和发展
16_one2 小时前
autoDL安装Open-WebUi+Rag本地知识库问答+Function Calling
人工智能·后端·算法
散峰而望4 小时前
C++数组(三)(算法竞赛)
开发语言·c++·算法·github
q***95224 小时前
SpringMVC 请求参数接收
前端·javascript·算法
初级炼丹师(爱说实话版)4 小时前
多进程与多线程的优缺点及适用场景总结
算法
hetao17338374 小时前
2025-11-25~26 hetao1733837的刷题记录
c++·算法
历程里程碑4 小时前
各种排序法大全
c语言·数据结构·笔记·算法·排序算法
少许极端5 小时前
算法奇妙屋(十四)-简单多状态dp问题
算法·动态规划·图解算法·简单多状态dp·打家劫舍问题·买卖股票问题全解