zoukankan      html  css  js  c++  java
  • 53寻找旋转排序数组中的最小值(153)

    作者: Turbo时间限制: 1S章节: 二分查找

    晚于: 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/

  • 相关阅读:
    KMP算法的理解和代码实现
    关于线程死锁
    PAT1018
    PAT1059
    PAT1009
    PAT1006
    PAT1005
    PAT1004
    PAT1002
    PAT
  • 原文地址:https://www.cnblogs.com/zmmm/p/13635304.html
Copyright © 2011-2022 走看看