搜索二维矩阵

搜索二维矩阵

直接用搜索二维矩阵Ⅱ的代码可以直接过掉

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int m=matrix.size()-1;
        int n=matrix[0].size()-1;
        int x=0,y=n;
        while(x<=m&&y>=0)//从右上角往左下角搜索,当前值大于目标值 y--,小于目标值则X++;
        {
            if(matrix[x][y]==target)
            {
                return true;
            }
            if(matrix[x][y]>target)
            {
                y--;
            }
            else x++;
        }
        return false;
    }
};

我们再练习一下二分吧在这里:

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int hang = -1;
        int n = matrix.size();
        for(int i = 0; i < n; i++) {
            // 判断最后一行或者检查到合适的行
            if (i == n-1 || (matrix[i][0] <= target && matrix[i+1][0] > target)) {
                hang = i;
                break;
            }
        }
        // 如果没找到合适的行,直接返回 false
        if (hang == -1) return false;

        int l=0,r=matrix[0].size()-1;
        while(l<r)
        {
            int mid=(l+r+1)>>1;
            if(matrix[hang][mid]>target) r=mid-1;
            else l=mid;
        }
        if(matrix[hang][r]!=target) return false;
        return true;
        
    }
};

然后就是可以进行数组拼接再二分。

然后就是找合适的行的时候,也可以用二分 时间复杂度就会从O(n)变为O(logn)

相关推荐
学涯乐码堂主37 分钟前
有趣的“打擂台算法”
c++·算法·青少年编程·gesp
Tutankaaa1 小时前
知识竞赛题库设计全攻略
人工智能·算法
WolfGang0073212 小时前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
aini_lovee3 小时前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab
yong99904 小时前
图像融合与拼接:完整MATLAB工具箱
算法·计算机视觉·matlab
春风不语5054 小时前
深入理解主成分分析(PCA)
算法
apollowing4 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二十二)
算法·启发式算法·web app
晚枫歌F4 小时前
最小堆定时器
数据结构·算法
Lumos_7774 小时前
Linux -- 线程
java·jvm·算法
七颗糖很甜5 小时前
“十五五”气象发展规划:聚焦五大核心任务
大数据·python·算法