博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[九度][何海涛] 旋转数组的最小数字
阅读量:4652 次
发布时间:2019-06-09

本文共 1953 字,大约阅读时间需要 6 分钟。

题目描述:

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

 

输入:

输入可能包含多个测试样例,对于每个测试案例,

输入的第一行为一个整数n(1<= n<=1000000):代表旋转数组的元素个数。

输入的第二行包括n个整数,其中每个整数a的范围是(1<=a<=10000000)。

 

输出:

对应每个测试案例,

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

 

样例输入:
53 4 5 1 2
样例输出:
1 一个修改版的二分查找
1 #include 
2 #include
3 using namespace std; 4 5 int a[1000000]; 6 7 int findPos(int a[], int left, int right) 8 { 9 if (left > right)10 return -1;11 12 int mid = left + (right - left) / 2;13 14 if (a[left] < a[mid])15 {16 int pos = findPos(a, mid + 1, right);17 if (pos == -1)18 return left;19 else20 return a[pos] < a[left] ? pos : left;21 }22 else if (a[left] > a[mid])23 {24 int pos = findPos(a, left, mid - 1);25 if (pos == -1)26 return mid;27 else28 return a[pos] < a[mid] ? pos : mid;29 }30 else31 {32 int pos1 = findPos(a, mid + 1, right);33 int pos2 = findPos(a, left , mid - 1);34 35 if (pos1 == -1 && pos2 == -1)36 return mid;37 else if (pos1 == -1)38 return a[mid] < a[pos2] ? mid : pos2;39 else if (pos2 == -1)40 return a[mid] < a[pos1] ? mid : pos1;41 else42 {43 if (a[pos1] < a[pos2])44 return a[mid] < a[pos1] ? mid : pos1;45 else46 return a[mid] < a[pos2] ? mid : pos2;47 }48 }49 }50 51 int main()52 {53 int n;54 while(scanf("%d", &n) != EOF)55 {56 for(int i = 0; i < n; i++)57 scanf("%d", &a[i]);58 59 int pos = findPos(a, 0, n - 1);60 61 cout << a[pos] << endl;62 }63 }

 

转载于:https://www.cnblogs.com/chkkch/archive/2012/11/23/2785037.html

你可能感兴趣的文章
使用 Nuget安装DLL
查看>>
18 Surprises From Reading jQuery’s Source Code
查看>>
004 方法反射
查看>>
根据 url 下载图片到本地
查看>>
node vue 开发环境部署时,外部访问页面出现: Invalid Host header 服务器域名访问出现的问题...
查看>>
逻辑运算符——逻辑与&&、逻辑或||
查看>>
系统管理-网络管理
查看>>
memmove和memcpy
查看>>
MongoDB整合Spring 详细讲解(含代码) .
查看>>
Java基础之IO
查看>>
asp.net中的App_GlobalResources和App_LocalResources使用
查看>>
集合类
查看>>
多列转1列 SqlServer 实现oracle10g的 wmsys.wm_concat()--for xml path('')
查看>>
Entity Framework应用:使用Code First模式管理视图
查看>>
【机器学习】贝叶斯公式
查看>>
445端口打开方法
查看>>
生成器
查看>>
Pycharm 创建 Django admin 用户名和密码
查看>>
python2.6升级2.7导致yum无法使用 No module named yum
查看>>
maintenance.go
查看>>