面试题:旋转数组的最小数字
题目:把一个数组的最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个递增数组的旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1.
算法:
(1)当输入的旋转数组非法时:处理!
(2)当输入的旋转数组正常时,index1 = 0;index2=length-1:
a:如果arry[index1]
b.1如果arry[index1] >arry[middle],index2 = middle;
b.2如果arry[index1] <= arry[middle],index1 = middle;
b.3 如果arry[index1] = arry[middle] = arry[index2],遍历找到最小值。
代码:
代码如下 | 复制代码 |
Min_RotateArray.hpp #pragma once usingnamespacestd;
intMin_RotateArray(intarry[],intsize) { if(arry == NULL || size <= 0) {cout<<"参数输入错误!!!"< intmin = 0; intindex1 = 0; intindex2 = size-1; intmiddle = (index1+index2)/2; if(arry[0] < arry[size-1]) returnarry[0]; while(arry[index1] >= arry[index2]) { if(index2-index1 == 1) { min=index2; break; } middle = (index1+index2)/2; if(arry[index1] <= arry[middle])//arry[middle]还在第一个递增序列中 { index1 = middle; } else { if(arry[index1] >= arry[middle])//arry[middle]在第二个递增序列中 {index2 = middle;} if(arry[index1] == arry[index2] && arry[index1] == arry[middle]) { for(inti=0;i { if(arry[min]>arry[i]) { min = i; break; } } } } } returnarry[min]; } Min_RotateArray.cpp #include"Min_RotateArray.hpp" intmain() { intarry[] = {3,4,5,1,2}; intsize =sizeof(arry)/sizeof(arry[0]); intmin = Min_RotateArray(arry,size); cout<<"The min is:"< system("pause"); return0; } |
茶杯头甜蜜终章dlc 官方手机版v1.0.0.3
下载火柴人传说暗影格斗内置菜单 最新版v3.0.1
下载荒野乱斗测试服 安卓版v61.10.3
下载荒野乱斗彩虹服 安卓版v61.10.3
下载寒霜启示录 安卓版v1.25.10
寒霜启示录是一款生存模拟游戏,不少玩家可能对于末日都有着自己
末日城堡免广告版 安卓最新版v0.7.1
末日城堡免广告版是一款非常好玩的模拟经营类游戏,内部可以不看
甜蜜人生模拟器 最新版v1.4.5
甜蜜人生模拟器是一款非常好玩的模拟恋爱手游,玩家在这里能够对
武器锻造师内置功能菜单 v10.4
武器锻造师内置菜单版是游戏的破解版本,在该版本中为玩家提供了
开放空间overfield 安卓版v1.0.5
开放空间Overfield是一款箱庭养成经营手游,让你在广阔