欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

Search a 2D Matrix

程序员文章站 2024-01-25 22:37:52
...

https://oj.leetcode.com/problems/search-a-2d-matrix/ 1、题目要求:在一个m×n的矩阵matrix里面查找目标target,如果查找成功返回true,否则返回false。 矩阵matrix的具有以下性质: 1)矩阵每行的元素从左到右递增排序; 2)每行的第一个元素比上一行的最

https://oj.leetcode.com/problems/search-a-2d-matrix/


1、题目要求:在一个m×n的矩阵matrix里面查找目标值target,如果查找成功返回true,否则返回false。

矩阵matrix的具有以下性质:

1)矩阵每行的元素从左到右递增排序;

2)每行的第一个元素比上一行的最后一个元素大;

例:假设个定矩阵如下,给定目标值target= 3, 则返回true.

[
  [1,   3,  5,  7],
  [10, 11, 16, 20],
  [23, 30, 34, 50]
]


2、解题思路:用每行的第一个元素进行二分查找,确定target所在行,然后在所在行进行二分查找;


class Solution {
public:
    bool searchMatrix(vector > &matrix, int target) {
        int n= matrix.size();
        int left= 0, right= n-1, mid;
        //首先找到target所在的行
        while(leftmatrix[mid][0])
                left= mid+1;
            else if(targetmatrix[row][mid])
                left= mid+1;
            else if(target