搜索旋转排序数组
Posted ych9527
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了搜索旋转排序数组相关的知识,希望对你有一定的参考价值。
1. 搜索旋转排序数组
整数数组 nums 按升序排列,数组中的值 互不相同 。
例如, [0,1,2,4,5,6,7] 在下标 3 处经旋转后可能变为 [4,5,6,7,0,1,2] 。
给你 旋转后 的数组 nums 和一个整数 target ,如果 nums 中存在这个目标值 target ,则返回它的下标,否则返回 -1 。
题目链接
class Solution {
public:
int search(vector<int>& nums, int target) {
int left=0;
int right=nums.size()-1;
while(left<=right)
{
int mid=left+(right-left)/2;
if(target>nums[right])
{
if(nums[mid]>target)
right=mid-1;
else if(nums[mid]<target)
{
if(nums[mid]>nums[right])
left=mid+1;
else
right=mid-1;
}
else
return mid;
}
else
{
if(nums[mid]>target)
{
if(nums[mid]<nums[right])
right=mid-1;
else
left=mid+1;
}
else if(nums[mid]<target)
left=mid+1;
else
return mid;
}
}
return -1;
}
};
2.在排序数组中查找元素的第一个和最后一个位置
给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。
如果数组中不存在目标值 target,返回 [-1, -1]。
题目链接
class Solution {
public:
vector<int> searchRange(vector<int>& nums, int target) {
vector<int> ret(2,-1);
int left=0;
int right=nums.size()-1;
while(left<=right)
{
int mid=left+(right-left)/2;
if(nums[mid]>target)
right=mid-1;
else if(nums[mid]<target)
left=mid+1;
else
{ ret[1]=mid;
left=mid+1;
}
}
left=0;
right=nums.size()-1;
while(left<=right)
{
int mid=left+(right-left)/2;
if(nums[mid]>target)
right=mid-1;
else if(nums[mid]<target)
left=mid+1;
else
{ ret[0]=mid;
right=mid-1;
}
}
return ret;
}
};
以上是关于搜索旋转排序数组的主要内容,如果未能解决你的问题,请参考以下文章