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;
}

相关推荐
brevity_souls几秒前
信息安全与网络安全的区别及其学习内容
网络·学习·web安全
YangYang9YangYan4 分钟前
2026学习数据分析对报考大数据专业的价值
大数据·学习·数据分析
speop6 分钟前
运行 Gemma4 大模型TASK01
学习
-To be number.wan6 分钟前
计算机组成原理 | 指令格式全解析
学习·计算机组成原理
MartinYeung525 分钟前
[论文学习]环境注入攻击(EIA)对通用网页代理的隐私洩露威胁
网络·学习
一口吃俩胖子33 分钟前
【脉宽调制DCDC功率变换学习笔记024】电压反馈补偿和环路增益
笔记·学习·算法
洛水水38 分钟前
【力扣100题】80.寻找旋转排序数组中的最小值
数据结构·算法·leetcode
YangYang9YangYan44 分钟前
数据科学与大数据技术专业学习数据分析的价值
大数据·学习·数据分析
70asunflower1 小时前
【Day1-2】部署&运行 Gemma4 大模型 - Datawhale AI学习
人工智能·学习·datawhale·amdev
洛水水1 小时前
【力扣100题】82.有效的括号
c++·算法·leetcode