当前位置: 首页 > article >正文

力扣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)


http://www.kler.cn/news/367657.html

相关文章:

  • Maven项目报错:invalid LOC header (bad signature)
  • 如何提高英语口语表达能力?
  • 【C++】抱C++中的函数式编程:使用`std::function`和Lambda表达式简化代码
  • springboot入门学习笔记
  • TensorFlow面试整理-模型部署与优化
  • 【云原生网关】Higress 从部署到使用详解
  • 2024-10-23 问AI: [AI面试题] 什么是卷积神经网络 (CNN)?
  • Vue 3 的响应式数据绑定(2)
  • 【LeetCode】每日一题 2024_10_21 最小差值 II(贪心)
  • redis 查找key使用正在表达式与java的区别
  • Linux的目录结构 常用基础命令(2)
  • Linux基础IO--重定向--缓冲区
  • 30. 串联所有单词的子串 C#实现
  • pip在ubuntu下换源
  • Android Studio超级详细讲解下载、安装配置教程(建议收藏)
  • 探索CSS动画下的按钮交互美学
  • MySQL 的元数据锁(Metadata Locks, MDL)原理详解
  • Python 协程详解----高性能爬虫
  • 适用在汽车诊断系统中的总线收发器芯片选型:CSM9241
  • Android AAR嵌套AAR打包出现问题解决方案
  • 自由学习记录(15)
  • 前端SSE-EventSource message事件执行异常问题
  • TypeScript(中)+算法(二)
  • 道可云人工智能元宇宙每日资讯|《嘉兴市推动人工智能高质量发展实施方案》发布
  • C/C++ 每日一练:二分查找
  • 【网络协议栈】Tcp协议(上)结构的解析 和 Tcp中的滑动窗口(32位确认序号、32位序号、4位首部长度、6位标记位、16为窗口大小、16位紧急指针)