首页 > 其他分享 >33. 搜索旋转排序数组

33. 搜索旋转排序数组

时间:2022-11-21 21:47:25浏览次数:50  
标签:下标 target nums 33 mid 旋转 数组 排序

整数数组 nums 按升序排列,数组中的值 互不相同 。

在传递给函数之前,nums 在预先未知的某个下标 k0 <= k < nums.length)上进行了 旋转,使数组变为 [nums[k], nums[k+1], ..., nums[n-1], nums[0], nums[1], ..., nums[k-1]](下标 从 0 开始 计数)。例如, [0,1,2,4,5,6,7] 在下标 3 处经旋转后可能变为 [4,5,6,7,0,1,2] 。

给你 旋转后 的数组 nums 和一个整数 target ,如果 nums 中存在这个目标值 target ,则返回它的下标,否则返回 -1 。

你必须设计一个时间复杂度为 O(log n) 的算法解决此问题。

示例 1:

输入:nums = [4,5,6,7,0,1,2], target = 0
输出:4

示例 2:

输入:nums = [4,5,6,7,0,1,2], target = 3
输出:-1

示例 3:

输入:nums = [1], target = 0
输出:-1

提示:

  • 1 <= nums.length <= 5000
  • -104 <= nums[i] <= 104
  • nums 中的每个值都 独一无二
  • 题目数据保证 nums 在预先未知的某个下标上进行了旋转
  • -104 <= target <= 104

方法一:二分法

 1 /**
 2  * @param {number[]} nums
 3  * @param {number} target
 4  * @return {number}
 5  */
 6 var search = function (nums, target) {
 7     let start = 0;
 8     let end = nums.length - 1;
 9     while (start <= end) {
10         let mid = (start + end) >> 1;
11         if (nums[mid] === target) {
12             return mid;
13         }
14         if (nums[mid] < nums[end]) {
15             if (nums[mid] < target && target <= nums[end]) {
16                 start = mid + 1;
17             } else {
18                 end = mid - 1;
19             }
20         } else {
21             if (nums[start] <= target && target < nums[mid]) {
22                 end = mid - 1;
23             } else {
24                 start = mid + 1;
25             }
26         }
27     }
28     return -1;
29 };

 

标签:下标,target,nums,33,mid,旋转,数组,排序
From: https://www.cnblogs.com/icyyyy/p/16913452.html

相关文章

  • CF1733E
    CF1733E给定一个初始箭头全部指向右的网格图,每时刻在\((0,0)\)新增一个黏球,之后黏球按照箭头指示运动一格,并将其刚才所在的上一个格子的箭头变换方向。箭头只会指向右......
  • 洛谷 P3336 [ZJOI2013]话旧
    洛谷P3336[ZJOI2013]话旧图是洛谷搞的做点简单的观察发现,每一次下降必须经过零点。对于每个点,有两种状态,从上面走过来,记为下降;从下面走过来,记为上升。\((0,0)\)我们......
  • CodeForces - 833B The Bakery
    看题解时全程:wow题意:给出n个数,将其按顺序分为k组,令每组的价值为该组不同的数的个数。求一种分法,使得所有组价值和最大。解:设dp[i][j]为将前j个数分为i组时的最大价值......
  • SHELL:echo -e "\033[字背景颜色;字体颜色m字符串\033[0m"
    格式:echo-e"\033[字背景颜色;字体颜色m字符串\033[0m" 例如: echo-e"\033[41;36msomethinghere\033[0m" 其中41的位置代表底色,36的位置是代表字的颜色 那些......
  • 【XSY3320】【LOJ6681】yww 与树上的回文串(border理论,点分治)
    咕了一年的题。先点分治。考虑某条经过当前重心\(rt\)的合法回文路径:(图摘自yww的题解)其中\(x\toy\)是合法回文路径,那么\(T\)是一个回文串。先把\(rt\)到每......
  • 页面点击按钮实现排序
    思路:用ajax实现局部div元素更新,新写一个要更新div部分的html页面modelsclassArticle(models.Model):title=models.CharField(max_length=100,verbose_nam......
  • PHP 之将数组拼接为sql语句
    一、代码/***拼接sql语句*@param$table*@param$array*@returnstring*/functioninsertSql($table,$array){$sqlk='';$sqlv='';foreach($arra......
  • 数组与指针总结
    一.前言在复习C语言和写实验的过程中对于指针数组模块做出的一些初学者的总结与看法。二.指针简介1.从根本来看,指针是一个值为内存地址的变量。可编写如下程......
  • 数组去重排序
    letdata=[{key:"01",value:"压缩",},{key:"02",value:"永恩",},{key:"03",value:"压缩",},{key:"04",value:"卢锡安",},]......
  • 【JavaScript 教程】第六章 数组17—flatMap() :对每个元素执行映射函数并将结果展平
    英文 | https://www.javascripttutorial.net/译文|杨小爱在上节,我们学习如何使用 JavaScriptArrayflat()方法来展平数组,错过的小伙伴可以点击文章《​​【JavaScrip......