力扣33:搜索旋转排序数组

整数数组 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

暴力解法:

复制代码
int search(int* nums, int numsSize, int target) {
    for(int i=0;i<numsSize;i++){
        if(nums[i]==target){
            return i;
        }
    }
    return -1;
}

时间复杂度O(n);空间复杂度O(1)

二分查找解法:

复制代码
int search(int nums[],int n,int target){
	//处理特殊情况
	if(n==0) return -1;
	if(n==1) return (nums[0]==target)?0:-1;
	
	int left=0,righ=n-1;
	while(left<=righ){
		int mid=(left+righ)/2;
		if(nums[mid]==target){
			return mid;//找到了 
		}
		//判断左表有序还是右表有序,将之间子看着是右表的第一个结点便一目了然
		if(nums[left]<=nums[mid]){//左表有序 
			if(nums[left]<=target&&target<nums[mid]){//target在左表中 
				righ=mid-1; 
			}else{
				left=mid+1;//target在右表中 
			}
		}else{//右表有序 
			if(nums[mid]<target&&target<=nums[righ]){//target在右表中 
				left=mid+1;
			}else{//target在左表中 
				righ=mid-1;
			}
		} 
		 
	} 
	return -1;//没有这个元素 
} 

时间复杂度O(logn);空间复杂度O(1)

相关推荐
zaiyang遇见20 分钟前
【递归完全搜索】CCC 2008 - 24点游戏Twenty-four
算法·游戏·c/c++·全排列·信息学奥赛
Python智慧行囊26 分钟前
排序算法总结
数据结构·算法
似水流年流不尽思念29 分钟前
常见的排序算法有哪些?它们的平均时间复杂度是多少?
后端·算法
楽码1 小时前
端到端应用Hmac加密
服务器·后端·算法
Morriser莫2 小时前
图论Day2学习心得
算法·图论
zyd09152 小时前
代码随想录Day50:图论(图论理论、深度搜索理论、所有可达路径、广度搜索理论)
java·数据结构·算法·leetcode·图论
Cl_rown去掉l变成C2 小时前
第R5周:天气预测
人工智能·python·深度学习·算法·tensorflow2
CoovallyAIHub2 小时前
VisDrone数据集,专为无人机视觉任务打造
深度学习·算法·计算机视觉
啊阿狸不会拉杆3 小时前
《算法导论》第 22 章 - 基本的图算法
c++·算法·排序算法·图论·拓扑学
Warren983 小时前
Java后端面试题(含Dubbo、MQ、分布式、并发、算法)
java·开发语言·分布式·学习·算法·mybatis·dubbo