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

【leetcode hot 100 240】搜索二维矩阵Ⅱ

解法一:直接查找

class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        for(int i=0; i<matrix.length; i++){
            for(int j=0; j<matrix[0].length; j++){
                if(matrix[i][j]>target){
                    break;
                }
                if(matrix[i][j]==target){
                    return true;
                }
            }
        }
        return false;
    }
}

解法二:二分查找

class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        for (int[] row : matrix) {
            int index = search(row, target);
            if (index >= 0) {
                return true;
            }
        }
        return false;
    }

    public int search(int[] nums, int target) {
        int low = 0, high = nums.length - 1;
        while (low <= high) {
            int mid = (high - low) / 2 + low;
            int num = nums[mid];
            if (num == target) {
                return mid;
            } else if (num > target) {
                high = mid - 1;
            } else {
                low = mid + 1;
            }
        }
        return -1;
    }
}

注意:

  • mid = (high - low) / 2 + low

解法三:(Z 字形查找)从右上角开始查找,若matrix[i][j]>target,则列减少;若matrix[i][j]<target,则列增加。

class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int i=0, j=matrix[0].length-1;
        while(i<matrix.length && j>=0){
            if(matrix[i][j]==target){
                return true;
            }
            if(matrix[i][j]>target){
                j--;
            }
            else{
                i++;
            }
        }
        return false;
    }
}

相关文章:

  • flutter环境最新踩坑
  • 什么是TiDB,什么是分布式数据库?它和 MySQL 比优缺点是什么?
  • 【大模型学习】第十一章 什么是算力
  • vue实现日历签到效果
  • 代码随想录算法训练营第三十二天 | 509. 斐波那契数 70. 爬楼梯 746. 使用最小花费爬楼梯
  • Cryptography 与 PyCryptodome 源码级解析
  • 爬虫逆向:脱壳工具BlackDex的详细使用
  • 发行思考:全球热销榜的频繁变动
  • [UE C++]实现自己的事件分发机制
  • Swift系列02-Swift 数据类型系统与内存模型
  • thinkphp5.1 在fetch模版就超时
  • Spring AI简单使用
  • 【JAVA架构师成长之路】【Spring生态】第1集:Spring生态核心
  • 使用QT + 文件IO + 鼠标拖拽事件 + 线程 ,实现大文件的传输
  • 在 macOS 上使用 CLion 进行 Google Test 单元测试
  • Van Uploader解决Android11及以下系统上传图片无反应问题
  • 【机械视觉】C#+visionPro联合编程———【一、C# + VisionPro 联合编程详解以及如何将visionPro工具加载到winform】
  • Web3 与跨链技术:如何实现不同区块链的互操作性
  • Language Agent Tree Search (1)
  • 春招中护网面试题库
  • 西安网站自然排名优化/企业网站搭建
  • wordpress主页图片不显示/南京seo优化公司
  • java程序员自己做网站/国内销售平台有哪些
  • 承德网站建设电话/百度快照优化推广
  • 怎样在本机建设网站/免费浏览网站推广
  • 网站建设内部风险分析/百度指数明星人气榜