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

力扣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.mrgr.cn/news/58936.html

相关文章:

  • 【JAVA】第三张_Eclipse下载、安装、汉化
  • 物联网海量数据下的时序数据库选型:InfluxDB、TDEngine、MongoDB与HBase对比与建议
  • 【Android】Kotlin教程(3)
  • GEE引擎传奇UI界面修改教程
  • 30岁转行学 IT 如何避免内卷?
  • Unity编辑器 连接不到SteamVR问题记录
  • 从Docker容器中备份整个PostgreSQL
  • 软考系统分析师知识点二三:错题集1-10
  • 并联谐振回路
  • 无人机原理是什么?
  • Linux下的线程同步与死锁避免
  • 从0到1构建 UniApp + Vue3 + TypeScript 移动端跨平台开源脚手架
  • 第15课 算法(上)
  • 快速入门!低功耗4G模组跟服务器之间的加密通信,千万不能错过!
  • 计算机强校99+分《数据库》课设
  • Web开发者必看:TypeScript的进阶用法与最佳实践
  • 动态规划 —— 0-1背包问题
  • vue开发的时候,目录名、文件名、函数名、变量名、数据库字段等命名规范
  • C++11中的同步互斥机制详解
  • 04 P1090 [NOIP2004 提高组] 合并果子 / [USACO06NOV] Fence Repair G
  • P1781 宇宙总统
  • MYSQL-查看创建的用户语法(十一)
  • 代码随想录算法训练营第二十七天 | 122.买卖股票的最佳时机Ⅱ 55.跳跃游戏 45.跳跃游戏Ⅱ 1005.K次取反后最大化的数组和
  • Web环境下的Spring Boot酒店房间预订系统
  • [答疑]是不是互联网更适合用DDD
  • 从零开始:构建一个高效的开源管理系统——使用 React 和 Ruoyi-Vue-Plus 的实战指南