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
}
相关推荐
阿豪学编程9 小时前
LeetCode724.:寻找数组的中心下标
算法·leetcode
墨韵流芳9 小时前
CCF-CSP第41次认证第三题——进程通信
c++·人工智能·算法·机器学习·csp·ccf
csdn_aspnet10 小时前
C# 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·算法·c#
禹中一只鱼10 小时前
【力扣热题100学习笔记】 - 哈希
java·学习·leetcode·哈希算法
凌波粒10 小时前
LeetCode--349.两个数组的交集(哈希表)
java·算法·leetcode·散列表
paeamecium11 小时前
【PAT甲级真题】- Student List for Course (25)
数据结构·c++·算法·list·pat考试
Book思议-12 小时前
【数据结构】栈与队列全方位对比 + C 语言完整实现
c语言·数据结构·算法··队列
SteveSenna12 小时前
项目:Trossen Arm MuJoCo
人工智能·学习·算法
NAGNIP12 小时前
一文搞懂CNN经典架构-DenseNet!
算法·面试
道法自然|~12 小时前
BugCTF黄道十二宫
算法·密码学