21.在有序的二位数组中用O(m+n)的算法找target

1.题目描述

2.解题思路

分析:

先遍历第一行找到第一个比target大的前一个数,如果没有就从右上角开始

向下找,找到大于target的数,回退列

向下找,重复

找到target直接return

3.代码

cpp 复制代码
bool searchMatrix(int** matrix, int matrixSize, int* matrixColSize, int target){
    //先遍历第一行找到第一个比target大的前一个数,如果没有就从右上角开始
    //向下找,找到大于target的数,回退列
    //向下找,重复
    //找到target直接return
    int row = matrixSize;
    int col = matrixColSize[0];
    int idx;//保存遍历起点
    if(row==1 && col==1 && matrix[0][0]!=target){
        return false;
    }
    for(int j =0 ;j<=col-1;j++){
        if(matrix[0][j]==target){
            return true;
        }else if(matrix[0][j]>target){
            idx = j-1;
            break;
        }
        idx = j;
    }
    int i = 0;//遍历行的下标
    while(idx>=0 && i<=row-1){
        if(matrix[i][idx]>target){//如果下面的大于target
        i--;
        idx--;
        }else if(matrix[i][idx]<target){
            i++;
        }else{
            return true;
        }
    }
    return false;
}
相关推荐
小尧嵌入式2 小时前
【Linux开发二】数字反转|除数累加|差分数组|vector插入和访问|小数四舍五入及向上取整|矩阵逆置|基础文件IO|深入文件IO
linux·服务器·开发语言·c++·线性代数·算法·矩阵
one____dream2 小时前
【算法】大整数数组连续进位
python·算法
one____dream2 小时前
【算法】合并两个有序链表
数据结构·python·算法·链表
大江东去浪淘尽千古风流人物2 小时前
【Project Aria】Meta新一代的AR眼镜及其数据集
人工智能·嵌入式硬件·算法·性能优化·ar·dsp开发
电饭叔2 小时前
has_solution = False 是什么 费马大定律代码化和定理《计算机科学中的数学》外扩学习3
学习·算法
We་ct2 小时前
LeetCode 238. 除了自身以外数组的乘积|最优解详解(O(n)时间+O(1)空间)
前端·算法·leetcode·typescript
闻缺陷则喜何志丹2 小时前
【动态规划】P9980 [USACO23DEC] Flight Routes G|普及+
c++·算法·动态规划·洛谷
Σίσυφος19002 小时前
视觉矩阵之 正交矩阵
人工智能·算法·矩阵
wen__xvn2 小时前
基础算法集训第21天:Bellman-Ford
算法