leetcode 33.搜索旋转排序数组

⭐️ 题目描述


🌟 leetcode链接:搜索旋转排序数组

ps: 本题是二分查找的变形,旋转排序数组之后其实会形成两个有序的区间 。算出平均下标先判断是否与 target 相等,因为这样可以减少代码的冗余。如果前者不成立则使用平均下标元素 midIndex 与 数组最后一个元素判断大小(因为我们可以确定第二个有序区间的最大值,而确定不了第一个有序区间的最大值),若小于则当前 midIndex 就在第二个有序区间中,反之在第一个有序区间。知道在哪个区间后,在判断 target 是否在这个区间中以及 nums[midIndex]target 的大小。

代码:

c 复制代码
int search(int* nums, int numsSize, int target){
    int left = 0;
    int right = numsSize - 1;
    while (left <= right) {
        int midIndex = left + ((right - left) / 2);
        if (nums[midIndex] == target) {
            return midIndex;
        } else if (nums[midIndex] < nums[right]) {
            // 在第二个有序区间
            if (target <= nums[right] && nums[midIndex] < target) {
                left = midIndex + 1;
            } else {
                right = midIndex - 1;
            }
        } else {
            // 第一个有序区间
            if (target >= nums[left] && nums[midIndex] > target) {
                right = midIndex - 1;
            } else {
                left = midIndex + 1;
            }
        }
    }
    return -1;
}

相关推荐
南境十里·墨染春水12 小时前
线程池学习(二)线程池理解
java·jvm·学习
aaaak_13 小时前
PDD 直播间 评论 , wss hex Protobuf 解析流程分析学习
java·前端·学习
小雅痞13 小时前
[Java][Leetcode simple] 205. 同构字符串
java·算法·leetcode
东风破13713 小时前
DM8达梦分布式计算数据库集群DPC安装部署学习记录
数据库·学习
空太Jun13 小时前
Git 使用学习笔记
笔记·git·学习
焜昱错眩..13 小时前
力扣周赛难题 3906.统计网格路径中好整数的数目——自我拆解学习与分析(数位dp上下界的奇妙)
学习·算法·leetcode·动态规划
空中海13 小时前
Git-01:基础篇 — 版本控制与日常操作
git·学习
happymaker062613 小时前
Spring学习日记——DAY06(事务管理)
java·学习·spring
兰令水13 小时前
topcode【随机算法题】【2026.5.14打卡-java版本】
java·算法·leetcode
小辉同志14 小时前
72. 编辑距离
leetcode·多维动态规划