【算法十九】33. 搜索旋转排序数组 74. 搜索二维矩阵

33. 搜索旋转排序数组

二分:

java 复制代码
class Solution {
    public int search(int[] nums, int target) {
        int n = nums.length;
        if(n == 0){
            return -1;
        }
        if(n == 1){
            return nums[0]==target?0:-1;
        }
        
        int l = 0;
        int r = n-1;
        while(l<=r){
            int mid = l+(r-l)/2;
            if(nums[mid] == target){
                return mid;
            }
            // 在看这种算法题时,如果对某个边界条件存疑,最好的办法就是拿一个n=2的数组模拟一下,
            // 通常90%的边界Bug都会在n=2时现形
            if(nums[0] <= nums[mid]){
                //这里不写target<=nums[mid]是因为前面判断过了target和nums[mid]的关系
                if(nums[0]<=target && target<nums[mid]){
                    r = mid-1;
                }
                else{
                    l = mid + 1;
                }
            }
            else{
                if(nums[mid]<target && target<=nums[n-1]){
                    l = mid + 1;
                }
                else{
                    r = mid - 1; 
                }
            }
        }
        return - 1;
    }
}

时间复杂度:O(logN)

空间复杂度:O(1)

74. 搜索二维矩阵

二分:

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int m = matrix.length;
        int n = matrix[0].length;

        int left = 0;
        int right = m*n-1;

        while(left <= right){
            int mid = left + (right-left)/2;
            int x = matrix[mid/n][mid%n];
            if(x == target){
                return true;
            }
            else if(x < target){
                left = mid + 1;
            }
            else{
                right = mid - 1;
            }
        }
        return false;
    }
}

时间复杂度:O(logMN)

空间复杂度:O(1)

核心:把二维数组展开成一行数组,找对应下标(i)与行与列的关系,row = i/n col = i%n

相关推荐
浮芷.3 小时前
鸿蒙PC端 TTS 并发调用问题详解:资源竞争与队列管理
算法·华为·开源·harmonyos·鸿蒙·鸿蒙系统
AI科技星4 小时前
精细结构常数α的多维度物理比值特性及空间螺旋模型研究
人工智能·线性代数·架构·概率论·学习方法
装不满的克莱因瓶4 小时前
掌握感知器的学习原理
人工智能·python·神经网络·算法·ai·卷积神经网络
Lsk_Smion4 小时前
力扣实训 _ [994].腐烂的橘子/图论
算法·leetcode·图论
轻微的风格艾丝凡4 小时前
两电平三相VSC整流模式从不控整流平滑切换至有源整流调试记录
算法·dsp·c2000
dongf20194 小时前
R语言KNN算法
算法·数据分析·r语言
小O的算法实验室4 小时前
2025年IEEE TASE,基于双层耦合平均场博弈的大规模智能体集成任务分配与轨迹规划
人工智能·算法·机器学习
8Qi84 小时前
LeetCode 337:打家劫舍 III(House Robber III)—— 题解 ✅
算法·leetcode·二叉树·动态规划
地平线开发者4 小时前
从 INT64 Div 算子约束到 Cast 修复全流程
算法
AI科技星4 小时前
基于奇合数边界的离散解析数论与双螺旋宇宙本体大统一体系论文全部数学公式汇总表
人工智能·算法·机器学习·架构·学习方法