在旋转过的有序数组中寻找目标值(NC48/考察次数Top34/难度简单)
Posted 码农指南
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在旋转过的有序数组中寻找目标值(NC48/考察次数Top34/难度简单)相关的知识,希望对你有一定的参考价值。
描述:
给定一个整数数组nums,按升序排序,数组中的元素各不相同。
nums数组在旋转过后比如,数组[0,2,3,6,9,10]在下标2处旋转之后变为[6,9,10,0,2,3]
现在给定一个旋转后的数组nums和一个整数target,请查找这个数组是否存在target,如果存在,那么返回它的下标,如果不存在,返回-1
示例1
输入:
[6,9,10,0,2,3],10
返回值:
2
(题目来自牛客网)
用C++实现如下
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param nums int整型vector
* @param target int整型
* @return int整型
*/
int search(vector<int>& nums, int target) {
int n=nums.size();
// //思路1,使用for循环进行处理
// for(int i=0;i<n;++i){
// if(nums[i]==target){
// return i;
// }
// }
// return -1;
//思路2,使用二分法进行求解
int left=0;
int right=nums.size()-1;
while(left<=right){
int mid=left+(right-left)/2;
if(nums[mid]==target){ //说明nums[mid]不是要求的值
return mid;
}
//有序数组经过旋转后,首先需要判断那一边是有序的
if(nums[left]<nums[mid]){ //左边有序递增;
if(target>=nums[left]&&target<nums[mid]){
right=mid-1;
}else{
left=mid+1;
}
}else{ //右边有序递增;
if(target>nums[mid]&&target<=nums[right]){
left=mid+1;
}else{
right=mid-1;
}
}
}
return -1;
}
};
纯手撕代码,如果觉得内容不错麻烦点个赞,后面陆续配上Top100算法题通俗易懂的讲解视频,可以花两个月时间完全掌握,进大厂不是梦,转行狗亲测!
以上是关于在旋转过的有序数组中寻找目标值(NC48/考察次数Top34/难度简单)的主要内容,如果未能解决你的问题,请参考以下文章