剑指Offer面试题:6.旋转数组中的最小数字建议收藏

一题目:旋转数组中的最小数字这道题最直观的解法并不难,从头到尾遍历数组一次,我们就能找出最小的元素。这种思路的时间复杂度显然是O(n)。但是这个思路没有利用输入的旋转数组的特性,肯定达不到面试官的

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

全栈程序员社区此处内容已经被作者隐藏,请输入验证码查看内容
验证码:
请关注本站微信公众号,回复“验证码”,获取验证码。在微信里搜索“全栈程序员社区”或者“www_javaforall_cn”或者微信扫描右侧二维码都可以关注本站微信公众号。

一 题目:旋转数组中的最小数字

题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。

  这道题最直观的解法并不难,从头到尾遍历数组一次,我们就能找出最小的元素。这种思路的时间复杂度显然是O(n)。但是这个思路没有利用输入的旋转数组的特性,肯定达不到面试官的要求

  我们注意到旋转之后的数组实际上可以划分为两个排序的子数组,而且前面的子数组的元素都大于或者等于后面子数组的元素。我们还注意到最小的元素刚好是这两个子数组的分界线。在排序的数组中我们可以用二分查找法实现O(logn)的查找

二 代码实现

#include "stdio.h"
#include <iostream>
using namespace std;

#include <assert.h>

// 遍历序列,找到最小值
int NormalFindMinVal(int *pStart, int *pEnd)
{
    assert(pStart != NULL && pEnd != NULL);
    int min = *pStart++;
    while(pEnd - pStart >= 0)
    {
        if (min > *pStart)
        {
            min = *pStart;
        }

        pStart++;
    }
    return min;
}

int SearchMinInRotateaArr_1(int *pStart, int *pEnd)
{
    if (pStart == NULL || pEnd == NULL)
    {
        return -1;
    }
    if (pEnd - pStart == 1)
    {
        return *pEnd;
    }

    int *pMid = NULL;
    
    pMid = pStart + (pEnd - pStart) / 2;
    
    if (*pMid >= *pStart && *pMid <= *pEnd)
    {
        return NormalFindMinVal(pStart, pEnd);
    }
    if (*pMid >= *pStart)
    {
        pStart = pMid;
    }
    else if(*pMid <= *pEnd)
    {
        pEnd = pMid;
    }
    
    return SearchMinInRotateaArr_1(pStart, pEnd);
}

// 找到旋转数组中的最小数字
int SearchMinInRotateaArr(int arr[], int nLen)
{
    assert(arr != NULL && nLen > 0);

    int *pStart,*pEnd;
    pStart = arr;
    pEnd = pStart + nLen -1;
    
    return SearchMinInRotateaArr_1(pStart, pEnd);
}

int a[] = {3,4,5,1,2};
int b[] = {1,1,1,0,1,1};
int c[] = {1,2,3,4,5};
void main()
{
    int data = SearchMinInRotateaArr(a,sizeof(a)/sizeof(a[0]));
    cout << data << endl;
    data = SearchMinInRotateaArr(b,sizeof(b)/sizeof(b[0]));
    cout << data << endl;
    data = SearchMinInRotateaArr(c,sizeof(c)/sizeof(c[0]));
    cout << data << endl;
    return;
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/120169.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 学习大数据需要掌握哪些Java技术

    学习大数据需要掌握哪些Java技术大数据产业已进入发展的”快车道”,急需大量优秀的大数据人才作为后盾。如果你是Java编程出身,那学习大数据自然是锦上添花;但如果你是刚刚接触大数据技术,还在Java编程基础阶段,这篇文章非常值得你看!首先,我们学习大数据,为什么要先掌握Java技术?Java是目前使用非常广泛的编程语言,它具有的众多特性,特别适合作为大数据应用的开发语言。Java不仅吸收了C++语言的各种优点…

    2022年5月12日
    63
  • pycharm用anaconda的Python_pycharm配置anaconda环境

    pycharm用anaconda的Python_pycharm配置anaconda环境先附上链接两个,是我自己用的pycharm链接:https://pan.baidu.com/s/1O5PixlPNpUw3RcxYbHHdBQ密码:vgjy下面是我自己用的Anaconda,版本是Anaconda2-5.0.1-Windows-x86_64链接:https://pan.baidu.com/s/16jiiYDtH9pVZTz6Ix7FeIQ密码:0yzmAnaco…

    2022年8月27日
    10
  • webstorm2021激活码_通用破解码

    webstorm2021激活码_通用破解码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月17日
    277
  • Navicat 15 for MySQL手动激活码_通用破解码

    Navicat 15 for MySQL手动激活码_通用破解码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月17日
    371
  • 如何使用fdisk

    如何使用fdisk

    2021年7月27日
    60
  • Python优秀开源项目Rich源码解析

    Python优秀开源项目Rich源码解析这篇文章对优秀的开源项目Rich的源码进行解析,OMG,盘他。为什么建议阅读源码,有两个原因,第一,单纯学语言很难在实践中灵活应用,通过阅读源码可以看到每个知识点的运用场景,印象会更深,以后写代码的时

    2022年7月5日
    27

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号