题目描述

把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。
# -*- coding:utf-8 -*-
class Solution:
def minNumberInRotateArray(self, rotateArray):
#由于数组(Array)可以分为两个部分有序的子数组,在排序的数组中可以考虑利用二分查找法实现。
#用两个指针分别指向数组的第一个元素(low)和最后一个元素(high),
#接着可以找到数组中间的元素(mid = (low+high)/2),
#如果中间元素位于前面的递增子数组中,则arr[mid] >= arr[low],
#此时数组中最小的元素应该位于该中间元素的后面。我们可以用指针low指向该中间元素low = mid,缩小搜索范围。
#移动之后的第二个指针high仍然位于后面的递增子数组中。
#如果中间元素位于后面的递增子数组,那么arr[mid] <= arr[high],
#此时输出中最小的元素应该位于该中间元素的前面,我们可以用指针high指向该中间元素high = mid。
#low总是指向前面递增子数组的元素,而high总是指向后面递增子数组的元素。最终low指向前面子数组的最后一个元素,
#而high指向后面子数组的第一个元素,即它们会指向两个相邻的元素,而此时high指向的刚好是最小的元素,
# write code here
n = len(rotateArray)
if n == 0: #空数组,直接返回0
return 0
low = 0 #初始化元素长度
high = n - 1
#如果把第0个元素移到最后,即数组有序,返回第一个元素即可
if rotateArray[low] < rotateArray[high]:
return rotateArray[low]
else:
#两个指针最终会指向两个相邻的元素,第二个指针指向最小的元素
while (high - low) > 1:
mid = (low + high)/2
#如果中间元素位于前面的递增子数组中
if rotateArray[low] <= rotateArray[mid]:
low = mid
#如果中间元素位于后面的递增子数组中
elif rotateArray[mid] <= rotateArray[high]:
high = mid #当首元素等于尾元素等于中间值时,只能在这个区域顺序查找,如[1,1,1,0,0,0,1,1]。
elif rotateArray[low] == rotateArray[high] and rotateArray[low] == rotateArray[mid]:
for i in range(n):
if rotateArray[i] < rotateArray[0]:
result = rotateArray[i]
high = i
result = rotateArray[high]
return result

 

#include<iostream>
#include<vector>
using namespace std;
class Solution
{
public:
int minNumberInRotateArray(vector<int> rotateArray)
{
int size = rotateArray.size();
int i;
if (size == 0)
return 0;
if (size == 1)
return rotateArray[0];
for (i = 1; i<size; i++)
{
if (rotateArray[i]<rotateArray[i - 1])
return rotateArray[i];
}
return rotateArray[0];
}
};
int main()
{
vector<int>vec;
int a[1000];
int i = 0;
int x;
while (cin >> a[i])
{
x = cin.get();
if (x == '\n')
break;
vec.push_back(a[i]);
++i;
}
vector<int>result(Solution().minNumberInRotateArray(vec));
for (int j = 0; j < result.size(); j++){
cout << result[j]<<" ";
cout << endl;
}
system("pause");
return 0;
}

  

 

旋转数组的最小数字(python)的更多相关文章

  1. 剑指Offer面试题:7.旋转数组的最小数字

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

  2. 旋转数组的最小数字(JAVA)

    旋转数组的最小数字 题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1,2}为{1,2 ...

  3. 剑指offer【06】- 旋转数组的最小数字(java)

    题目:旋转数组的最小数字 考点:查找和排序 题目描述:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4, ...

  4. 剑指offer编程题Java实现——面试题8旋转数组的最小数字

    剑指offer面试题8:旋转数组的最小数字 题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转.输入一个递增排序数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1, ...

  5. 【Java】 剑指offer(10) 旋转数组的最小数字

    本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. ...

  6. 《剑指offer》第十一题(旋转数组的最小数字)

    // 面试题:旋转数组的最小数字 // 题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. // 输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素.例如数组 // {3, ...

  7. 《剑指offer》— JavaScript(6)旋转数组的最小数字

    旋转数组的最小数字 题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素.例如数组{3,4,5,1,2}为{1,2, ...

  8. 【C语言】求旋转数组的最小数字,输入一个递增排序的数组的一个旋转,输出其最小元素

    //求旋转数组的最小数字,输入一个递增排序的数组的一个旋转,输出其最小元素 #include <stdio.h> #include <string.h> int find_mi ...

  9. 【剑指offer】面试题 11. 旋转数组的最小数字

    面试题 11. 旋转数组的最小数字 题目描述 题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4, ...

随机推荐

  1. 关于Linux(时间网路同步)

    Linux 时间同步只针对命令行界面,图形界面请自行摸索. 转自Linux下ntpdate时间同步

  2. 运行官方mysql 镜像

    sudo docker run -it -d --restart unless-stopped -p 13306:3306 -h mysql --name mysql -e MYSQL_ROOT_PA ...

  3. 开源小程序CMS网站, JeeWx-App-CMS 1.0 首版本发布

    JeeWx-App-CMS 是jeewx开发的小程序网站开源项目,基于小程序wepy语言,具备cms网站的基本功能,能够打造简单易用的小程序公司官网.项目结构简单,逻辑清晰,代码规范,非常适合作为小程 ...

  4. vue - @click 用到的修饰符

    1.vue提供的方法 .stop .prevent .capture .self .once .passive <!-- 阻止单击事件继续传播 --><a v-on:click.st ...

  5. ACM__容器之vector

    今天做题碰到了深搜的题,有一种存图方式需要用到vector,对vector不是很熟悉,回顾了一下 vector都知道是一个容器,但并不准确,它是一个多功能的能够操作多种数据结构和算法的模板类和函数库. ...

  6. 打开Delphi 10.2提示脚本错误的解决方法

    HKEY_CURRENT_USER\SOFTWARE\Embarcadero\BDS\18.0\Known IDE Packages $(BDS)\Bin\CommunityToolbar240.bp ...

  7. mysql索引小结——高性能mysql

    1.索引可以包含一个或者多个列的值,如果索引包含多个列的值,列的顺序很重要,mysql只能高效地使用索引的最左列前缀列. 2.索引是在存储引擎层而非服务器层实现的. 3.B-tree索引的限制: 如果 ...

  8. uml用例关系

    关联关系 关联关系是指执行者与用例之间的关系,又称为通信关系,如果某个执行者可以对某个用例进行操作,它们之间就具有关联关系,如下图所示,“经理”有一个功能为“查看库存报表”,因此可以在执行者“经理”和 ...

  9. 转: python requests的安装与简单运用

    requests是Python的一个HTTP客户端库,跟urllib,urllib2类似,那为什么要用requests而不用urllib2呢? 官方文档中是这样说明的: python的标准库urlli ...

  10. [Nginx]实战Nginx:Nginx服务器的安装与配置

    ----------------------------------------------------------------------------------------------- Ngin ...