剑指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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux 查看当前所有环境变量的两种方法_Linux配置jdk环境变量

    linux 查看当前所有环境变量的两种方法_Linux配置jdk环境变量linux中查看环境变量有两种方法:第一种是看系统环境变量的配置文件:/etc/profile这个是环境变量配置文件,里面是应经配置号的环境变量。当你在Ubuntu上安装配置jdk的JAVA_HOME时,需要把路径配置在里面。例如:在bash下输入gedit/etc/profile#/etc/profile:system-wide.profilefilefortheBournes…

    2022年10月1日
    2
  • python进阶(4)文件操作

    python进阶(4)文件操作文件操作文件操作主要包括对文件内容的读写操作,这些操作是通过文件对象实现的,通过文件对象可以读写文本文件和二进制文件open(file,mode='r',buffering=-

    2022年7月30日
    6
  • pycharm提示代码功能问题「建议收藏」

    pycharm提示代码功能问题「建议收藏」在使用pycharm写python代码时,对于tensorflow模块,不能显示代码提示内容。在project中设置解释器地址后, 要等待下面列出的package包全部扫描完,显示完当前版本和最新版本完,再点OK按钮。在代码区输入相关类的点后,要稍微等一会,才会出现代码提示的信息。…

    2022年8月29日
    4
  • UML的9种常用图与建模工具详解「建议收藏」

    UML的9种常用图与建模工具详解「建议收藏」UML即UnifiedModelLanguage,是一种建模语言,也是标准建模语言。在软件开发中,当系统规模比较复杂时,需要用图形抽象地来表达复杂的概念,让整个软件设计更具有可读性,可理解性,以便

    2022年7月4日
    101
  • pip安装教程

    直接搜索pippip官网地址会得到下面的图像下载短的那个(如果你不知道pip是否安装可以通过命令pip–version来判断是否已安装)下载完成后解压到你自己知道的文件夹防止找不到,,然后有两种方法安装pip第一种在python环境下安装pippy-mensurepip–upgrade(直接在python里面运行cmd输入这一行代码)第二种可以用python中的内置脚本python内置脚本pyget-pip.py(下载到python文件中打开cmd,然后..

    2022年4月9日
    60
  • java标识符命名_java标识符命名规则「建议收藏」

    java标识符命名_java标识符命名规则「建议收藏」1.标识符概念:对于java中的类、接口、变量、常量、方法、属性等等命名的字段被称作标识符。通俗的说就是起名字的地方就是标示符。2标识符命名规则:(1).标识符一般有字母、数字、下划线_、美元符$、人民币符号¥组成。(2).注意数字不能放开头(3).不能把java关键字(例如publicint)作为标识符(4).不能把java保留字(goto,const)作为标识符(5).标识符没有长度限制,并…

    2022年7月26日
    8

发表回复

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

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