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;
}
相关推荐
赵域Phoenix5 分钟前
混沌系统是什么?
人工智能·算法·机器学习
CoderCodingNo10 分钟前
【GESP】C++五、六级练习题 luogu-P1886 【模板】单调队列 / 滑动窗口
开发语言·c++·算法
paeamecium11 分钟前
【PAT甲级真题】- All Roads Lead to Rome (30)
数据结构·c++·算法·pat考试·pat
Cando学算法17 分钟前
双指针之快慢指针
算法
汀、人工智能26 分钟前
[特殊字符] 第100课:任务调度器
数据结构·算法·数据库架构·贪心··任务调度器
每日任务(希望进OD版)28 分钟前
二分法刷题
算法·二分
会编程的土豆1 小时前
日常做题 vlog
数据结构·c++·算法
Omigeq1 小时前
1.4 - 曲线生成轨迹优化算法(以BSpline和ReedsShepp为例) - Python运动规划库教程(Python Motion Planning)
开发语言·人工智能·python·算法·机器人
网络工程小王2 小时前
【大模型(LLM)的业务开发】学习笔记
人工智能·算法·机器学习
y = xⁿ2 小时前
【Leet Code 】滑动窗口
java·算法·leetcode