剑指Offer-旋转数组的最小数字
来源:互联网 发布:高德地图js api 编辑:程序博客网 时间:2024/04/29 09:34
题目描述:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。
NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。
注意:二分查找的条件是数组有序,而此题的是把有序数组做了一次旋转。
int minNumberInRotateArray(vector<int> rotateArray) { //类似二分查找,时间复杂度为log(n) int low = 0, high = rotateArray.size() -1; while(low < high) { //当low和high相遇时,查询范围缩小到只有一个元素时,那么这个就是最小的数。 int mid = low + (high - low)/2; //防止数组越界 if(rotateArray[mid] > rotateArray[high]) { low = mid + 1; } else if(rotateArray[mid] == rotateArray[high]) { high = high -1; } else { high = mid; } } return rotateArray[low]; }
0 0
- 【剑指offer】旋转数组的最小数字
- 剑指offer--旋转数组的最小数字
- 剑指offer--旋转数组的最小数字
- 剑指offer:旋转数组的最小数字
- 《剑指offer》旋转数组的最小数字
- 剑指 offer:旋转数组的最小数字
- 剑指offer-旋转数组的最小数字
- 剑指offer 旋转数组的最小数字
- 【剑指offer】旋转数组的最小数字
- 剑指offer 旋转数组的最小数字
- 剑指offer-旋转数组的最小数字
- 剑指Offer:旋转数组的最小数字
- 剑指Offer 旋转数组的最小数字
- 剑指offer|旋转数组的最小数字
- 剑指offer:旋转数组的最小数字
- 【剑指offer】旋转数组的最小数字
- 《剑指offer》旋转数组的最小数字
- 剑指Offer:旋转数组的最小数字
- SpringMVC学习心得
- android屏幕适配方案
- Android病毒分析技巧和方法总结
- java web 前台使用枚举
- java程序的执行顺序
- 剑指Offer-旋转数组的最小数字
- Python学习-windows安装Python以及matplotlib.pyplot包
- 欢迎使用CSDN-markdown编辑器
- QEMU命令行参数启动虚拟机
- 视图概述
- 利用SQL索引提高查询速度
- #include "" 和 #include <> 区别问题
- 新安装的Ubuntu16.04之后的事情
- 代码块面试题1