【奇技淫巧】-- 搜索旋转数组
发布日期:2021-06-30 19:45:54 浏览次数:2 分类:技术文章

本文共 1222 字,大约阅读时间需要 4 分钟。

假设按照升序排序的数组在预先未知的某个点上进行了旋转。

( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] )。

搜索一个给定的目标值,如果数组中存在这个目标值,则返回它的索引,否则返回 -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

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/search-in-rotated-sorted-array
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

思路

这题让我知道,天下大事,必做于细啊。

用题目中给的例子来分析,对于数组[0 1 2 4 5 6 7] 共有下列七种旋转方法:

在这里插入图片描述
二分搜索法的关键在于获得了中间数后,判断下面要搜索左半段还是右半段,我们观察上面红色加粗的数字都是升序的,由此我们可以观察出规律,如果中间的数小于最右边的数,则右半段是有序的,若中间数大于最右边数,则左半段是有序的,我们只要在有序的半段里用首尾两个数组来判断目标值是否在这一区域内,这样就可以确定保留哪半边了,代码如下

int search(vector
& nums, int target) {
int n = nums.size(); if (n == 0) return -1; int left = 0, right = n - 1; while (left <= right) {
int mid = (left + right) / 2; if (nums[mid] == target) return mid; else if (nums[mid] < nums[right]) {
if (nums[mid] < target && nums[right] >= target) left = mid + 1; else right = mid - 1; } else {
if (nums[left] <= target && nums[mid] > target) right = mid - 1; else left = mid + 1; } } return -1; }

转载地址:https://lion-wu.blog.csdn.net/article/details/107616660 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:【奇技淫巧】-- 二叉树中的最大路径和
下一篇:【奇技淫巧】-- 原地旋转链表

发表评论

最新留言

表示我来过!
[***.240.166.169]2024年04月24日 04时50分02秒