温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

c++怎么实现旋转数组最小数字

发布时间:2022-03-22 15:44:10 来源:亿速云 阅读:92 作者:iii 栏目:互联网科技

这篇文章主要介绍了c++怎么实现旋转数组最小数字的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇c++怎么实现旋转数组最小数字文章都会有所收获,下面我们一起来看看吧。

题目:把一个数组最开始的若干元素搬到数组的末尾,称之为数组的旋转。

          输入:一个递增排序的数组的一个旋转,

          输出:旋转数组的最小元素。

例:数组{3,4,5,1,2}是{1,2,3,4,5}的一个旋转,该数组的最小值为1.

分析:

1)旋转之后的数组可以划分为两个排序的子数组,而且前面子数组的元素都大于后等于后面子数组的元素。

2)最小的元素是这两个字数组的分界线。在排序的数组中,可以使用二分查找法(Ologn)

3)特例,当两个指针指向的数字及他们中间的数字三者相同的时候,无法判定中间的数字是位于前面的子数组还是后面的子数组,即无法移动两个指针来缩小查找范围。此时应采用顺序查找。

int Min(int* numbers,int length){    if(numbers==nullptr||length<=0)        throw new std::exception('invalid parameters')    int index1=0;//子数组1指针    int index2=length-1;//字数组2指针    int indexMid=index1;    while(numbers[index1]>=numbers[index2]){
       if(index2-idnex1==1)//两个指针相邻在一起时,指针2就是最小值        {
           indexMid=index2;            break;        }        indexMid=(index1+index2)/2;                //如果下表为index1/index2/indexMid指向三个数都相同,则顺序查找        if(numbers[index1]==numbers[indexMid]&&numbers[indexMid]==numbers[index2])            return MinInOrder(numbers,index1,index2);        if(numbers[indexMid]>=numbers[index1])            index1=indexMid;        else if(numbers[idnexMid]<=nubmers[index2])            index2=indexMid;    }return numbers[indexMid];}

//顺序排序int MinInOrder(int* numbers,int index1,int index2){
   int result=numbers[index1];    for(int i=index1+1;i<=index2;++i)    {      if(result>numbers[i])result=numbers[i];
   }    return result;
}

关于“c++怎么实现旋转数组最小数字”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“c++怎么实现旋转数组最小数字”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++
AI