作者:
晚于: 2020-08-12 12:00:00后提交分数乘系数50%
截止日期: 2020-08-19 12:00:00
问题描述 :
假设我们的数组是一个按照升序排序的数组在预先未知的某个点上进行了旋转得到的。
( 例如,数组 [3,5,6,0,1,2] ,可以知道是从[0,1,2,3,5,6] 旋转变来的 )。
请找出其中最小的元素。要求使用二分查找。
你可以假设数组中不存在重复元素。
示例 1:
输入: [3,4,5,1,2]
输出: 1
示例 2:
输入: [4,5,6,7,0,1,2]
输出: 0
输入说明 :
首先输入数组的长度n,然后输入n个整数
输出说明 :
输出一个整数
输入范例 :
输出范例 :
#include <iostream> #include <vector> using namespace std; class Solution { public: int findMin(vector<int>& nums) { int begin=0,end=nums.size()-1; if(nums.size()==1) return nums[0]; if(nums[end]>nums[0]) return nums[0]; while(begin<=end) { int mid=(end+begin)/2; if(nums[mid]>nums[mid+1]) return nums[mid+1]; if(nums[mid-1]>nums[mid]) return nums[mid]; if(nums[mid]>nums[begin]) begin=mid+1; else end=mid-1; } return -1; } }; int main() { int n,data; vector<int> nums; cin>>n; for(int i=0; i<n; i++) { cin>>data; nums.push_back(data); } int res=Solution().findMin(nums); cout<<res<<endl; return 0; }
https://leetcode-cn.com/problems/find-minimum-in-rotated-sorted-array/solution/xun-zhao-xuan-zhuan-pai-lie-shu-zu-zhong-de-zui-xi/