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
}
相关推荐
Cando学算法28 分钟前
AtCoder Beginner Contest 416(ABCDE)
c++·算法
zzywxc78743 分钟前
随着人工智能技术的飞速发展,大语言模型(Large Language Models, LLMs)已经成为当前AI领域最引人注目的技术突破。
人工智能·深度学习·算法·低代码·机器学习·自动化·排序算法
এ᭄画画的北北1 小时前
力扣-94. 二叉树的中序遍历
算法·leetcode
yu2024111 小时前
【异世界历险之数据结构世界(冒泡、选择、快速排序)】
数据结构·算法
1 小时前
LeetCode Hot 100 搜索旋转排序数组
数据结构·算法·leetcode
LZQqqqqo1 小时前
C#_创建自己的MyList列表
java·算法·c#
行然梦实2 小时前
论文阅读:《多目标和多目标优化的回顾与评估:方法和算法》
论文阅读·算法·机器学习·数学建模
castro2 小时前
斐波那契堆:理论强者与现实挑战——深入解析高效优先队列的实现与局限
算法
go54631584652 小时前
离散扩散模型在数独问题上的复现与应用
线性代数·算法·yolo·生成对抗网络·矩阵
惜鸟2 小时前
PDF页眉页脚识别与去除方案
后端·算法