旋转数组查找数字--力扣101算法题解笔记

4.4旋转数组查找数字

题目描述

一个原本增序的数组被首尾相连后按某个位置断开(如【1,2,2,3,4,5】->【2,3,4,5,1,2】为在第一位和第二位断开),我们称其为旋转数组。给定一个值,判断这个值是否存在于这个旋转数组中

输入输出样例

Input:nums = [2,5,6,0,0,1,2], target = 0

Output:true

输入一个数组和一个值,输出一个bool值。

题解

跟之前的题目大差不差,是类似两个数组都是递增的然后拼接一块。不过这个题里面的两个数组都是有序的且把这两个小数组拼接在一起也是有序的。所以仍然可以使用二分查找。对于当前的中点,如果它指向的值小于等于右端,那么就说明右边排好序了,反之,左边排好序。如果target在排好序的区间里了,那就可以在区间里进行二分查找。反之,对另一半的区间查找。

这里面有个小问题,就是可能数组存在重复的数组,要是中点和左端数字相同,就不能确定左右的数组情况,没准都是相同数字,也没准左边的小数组都跟中点相同。这个时候就给左端点向右移动一个,也不耽误整体的二分查找。因为他跟中点相同。

cpp 复制代码
#include <iostream>
#include <vector>
using namespace std;

bool search(vector<int>& nums, int target) {
    int start = 0, end = nums.size() - 1;
    while (start <= end) {
        int mid = start + (end - start) / 2;
        if (nums[mid] == target) {
            return true;
        }
        if (nums[start] == nums[mid]) {
            //不知道哪个区间是增序
            ++start;
        }
        else if(nums[mid] <= nums[end]) {
             //右区间是增序
            if (target > nums[mid] && target <= nums[end]) {
                start = mid + 1;
            }
            else {
                end = mid - 1;
            }
        }
        else {
            //左区间是递增的
            if (target >= nums[start] && target < nums[mid]) {
                end = mid - 1;
            }
            else {
                start = mid + 1;
            }
        }
    }
    return false;
}

int main() {
    vector<int> nums = { 5,7,7,8,8,10 };
    int target = 8;

    if (search(nums, target)) {
        cout << "true" << endl;
    }
    else {
        cout << "false" << endl;
    }

    return 0;
}
相关推荐
凌波粒13 小时前
LeetCode--383.赎金信(哈希表)
java·算法·leetcode·散列表
xiaoye-duck13 小时前
《算法题讲解指南:动态规划算法--子数组系列》--23.等差数列划分,24.最长湍流子数组
c++·算法·动态规划
小O的算法实验室13 小时前
2026年SEVC,高密度仓库中结合任务分配的多AGV无冲突调度框架,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
abant214 小时前
leetcode 108 有序数组转平衡二叉树
算法·leetcode·职场和发展
汀、人工智能14 小时前
[特殊字符] 第7课:移动零
数据结构·算法·数据库架构·图论·bfs·移动零
计算机安禾14 小时前
【数据结构与算法】第25篇:静态查找(一):顺序查找与折半查找
java·开发语言·数据结构·学习·算法·visual studio code·visual studio
B1acktion14 小时前
2.7.希尔排序——让插入排序先大步走,再小步收尾
c++·算法·排序算法
原来是猿14 小时前
Linux进程信号详解(一):信号快速认识
linux·c++·算法
py有趣14 小时前
力扣热门100题之翻转二叉树
算法·leetcode
醉城夜风~14 小时前
C++函数参数的默认值及其使用场景
开发语言·c++·算法