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

二分查找-153-寻找旋转排序数组中的最小值-力扣(LeetCode)

一、题目解析

1.旋转的本质是把最后的n个元素放到起始位置

2.nums数组的各个元素值是不同的

3.时间复杂度要求0(logN)

二、算法原理

解法1:暴力解法 O(N)

给定一个赋值为INT_MAX的变量,遍历数组,记录最小值,由于数组长度为5000,所以暴力解法是可以通过的,遍历数组因此时间复杂度为O(N)

解法2:二分查找+D为分界点

二段性

解法3:二分查找+A为分界点

这里需要判断是否为旋转数组,因为存在旋转后与原数组一致的情况,所以需要判断nums[0]是否大于nums[n-1],大于则为旋转数组,反之则不是

三、代码示例

解法1:

    int findMin(vector<int>& nums)//解法1{int ret = INT_MAX;for(auto e : nums){if(e<ret) ret = e;}return ret;}

 

解法2:

    int findMin(vector<int>& nums)//解法2:d为分界点{int n = nums.size();int left = 0,right = n-1;while(left < right){int mid = left + (right - left)/2;if(nums[mid]>nums[n-1]) left = mid + 1;else right = mid;}return nums[right];}

 

解法3:

    int findMin(vector<int>& nums)//解法3:a为分界点{int n = nums.size();if(nums[0]<nums[n-1]) return nums[0];int left = 0,right = n-1;while(left < right){int mid = left + (right - left)/2;if(nums[mid]<nums[0]) right = mid;else left = mid + 1;}return nums[right];}

 

看到最后,如果对您有所帮助,还请点赞、收藏和关注,我们下期再见! 

http://www.dtcms.com/a/296387.html

相关文章:

  • unordered_map和unordered_set特性以及解决哈希冲突
  • Gemini拿下IMO2025金牌的提示词解析
  • Redis Lua脚本语法详解
  • Redis ①⑦-分布式锁
  • 跨模态理解的基石:非文本内容向量化方法全景解析
  • Lua协同程序(coroutine)
  • leetcode100.相同的树(递归练习题)
  • Xilinx-FPGA-PCIe-XDMA 驱动内核兼容性问题修复方案
  • 基于单片机睡眠质量/睡眠枕头设计
  • 1.1.2 建筑构造要求
  • 无人机正摄影像自动识别与矢量提取系统
  • 用phpEnv安装Thinkphp8.x出错调试全过程记录
  • C++ 中打开文件的多种方式及相关流类
  • matplotlib的详细知识点
  • k8s之ingress定义https访问方式
  • 【AI News | 20250723】每日AI进展
  • Windows11 本地安装docker Desktop 部署dify 拉取镜像报错
  • iOS Core Data 本地数据库 使用详解:从模型关系到数据操作
  • 技嘉z370主板开启vtx
  • 谈谈ArrayList与Vector的理解?
  • SpringBoot+AI+Web3实战指南
  • Python循环结构
  • 红黑树:高效平衡的终极指南
  • c语言学习(dyas10)
  • Kubernetes Kubelet 资源配置优化指南:从命令行参数到配置文件的最佳实践
  • Spring AI - ChatModel接口演示
  • TCO,UDP考点
  • 开发避坑短篇(5):vue el-date-picker 设置默认开始结束时间
  • SpringBoot航空订票系统的设计与实现
  • 视频模型国产PK国外?