当前位置: 首页 > news >正文

LeetCode Hot100 搜索二维矩阵

给你一个满足下述两条属性的 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

思路

      第一次

        两次二分查找,先找行,再找列,注意数组不要越界。复杂度上logmn

      第二次

         当一维数组做,复杂度同logmn

代码

      第一遍

class Solution {
public:bool searchMatrix(vector<vector<int>>& matrix, int target) {int i = 0,j = matrix.size()-1;int m,row;while(i<=j){m = i+ (j-i)/2;if(matrix[m][0] == target)return true;else if(matrix[m][0] > target){j = m-1;}elsei = m+1;}if((row = i-1) < 0)return false;i = 0;j = matrix[0].size()-1;while(i<=j){m = i + (j-i)/2;if(matrix[row][m] == target)return true;else if(matrix[row][m] > target)j = m-1;elsei = m+1;}return false;}
};

         第二遍

class Solution {
public:bool searchMatrix(vector<vector<int>>& matrix, int target) {int i = 0,j = matrix.size()*matrix[0].size()-1;int m,size = matrix[0].size();int row,col;while(i<=j){m = i+ (j-i)/2;row = m/size;col = m%size;if(matrix[row][col] == target)return true;else if(matrix[row][col] > target){j = m-1;}elsei = m+1;}return false;}
};

http://www.lryc.cn/news/407688.html

相关文章:

  • iOS中的KVO(Key-Value Observing)详解
  • 算法 —— 暴力枚举
  • 构造+有序集合,CF 1023D - Array Restoration
  • Scrapy 爬取旅游景点相关数据(四)
  • Vue常用指令及其生命周期
  • 简化数据流:Apache SeaTunnel实现多表同步的高效指南
  • 均匀圆形阵列原理及MATLAB仿真
  • vue2使用univerjs
  • VUE3 el-table-column header新增必填*
  • 条件概率和贝叶斯公式
  • Kali中docker与docker-compose的配置
  • C++ | Leetcode C++题解之第283题移动零
  • Exponential Moving Average (EMA) in Stable Diffusion
  • 017、Vue动态tag标签
  • RocketMQ 架构概览
  • 优化医疗数据管理:Kettle ETL 数据采集方案详解
  • spring-from表单
  • 【.NET】asp.net core 程序重启容器后redis无法连接,连接超时
  • 【vue前端项目实战案例】Vue3仿今日头条App
  • 常见的文心一言的指令
  • 数字货币交易接口实现(含源代码)
  • c++函数以及函数分文件编写
  • 【JVM基础06】——组成-直接内存详解
  • 学术研讨 | 区块链与隐私计算领域专用硬件研讨会顺利召开
  • AngularJS API 深入解析
  • 过某开源滑动验证码
  • 一文解决 | Linux(Ubuntn)系统安装 | 硬盘挂载 | 用户创建 | 生信分析配置
  • Matlab M_map工具箱绘制Interrupted Mollweide Projection
  • Python 变量与基本数据类型
  • Pytorch深度学习实践(5)逻辑回归