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/

  • 相关阅读:
    ThreadPoolExecutor线程池参数设置技巧
    函数式接口
    Mac下进入MySQL命令行
    Java8 特性
    Java8 :: 用法 (JDK8 双冒号用法)
    事务传播
    新版IDEA配置tomcat教程(2018)
    Java8 Map的compute()方法
    Spring 普通类与工具类调用service层
    简单工厂(三)——JDK源码中的简单工厂
  • 原文地址:https://www.cnblogs.com/zmmm/p/13635304.html
Copyright © 2011-2022 走看看