题目描述

把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{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. yum-cron更新 CentOS yum update 不升级内核版本方法

    http://www.360doc.com/content/15/0608/17/15798950_476597844.shtml 相关yum-cron说明有一些 CentOS yum update ...

  2. kettle实现简单的增量同步

    下载 pdi-ce-7.0.0.0-25.zip 解压 安装jdk 1.7以上的版本 配置环境变量 下载并将mysql-connector-java-5.1.39.jar 拷贝到 \data-inte ...

  3. python3下全自动快速度在线安装所有插件

    把下面的内容复制存为pip.conf文件, [global]timeout = 60index-url = https://pypi.python.org/simple/no-cache-dir = ...

  4. Valgrind简单用法 (转)

    转自 http://www.cnblogs.com/sunyubo/archive/2010/05/05/2282170.html Valgrind的主要作者Julian Seward刚获得了今年的G ...

  5. 20165304《JAVA程序设计》第四周学习总结

    教材内容总结 第五章 子类与继承 1.子类声明中通常用关键字extend来定义一个子类(class 子类名 extend 父类名{}) 2.子类和父类在同一包中的继承性,继承的成员变量或方法的访问权限 ...

  6. wed开发基础--练习题

    一.HTML部分 本小节重点: 熟练使用div+span布局,知道div和span的语义化的意思 熟悉对div.ul.li.span.a.img.table.form.input标签有深刻的认知, 初 ...

  7. python字符串的基本用法

    var1 = "hello word"var2 = "runootab"print var2.capitalize()#首字母大写print (var2.cou ...

  8. 关于 SAXParseException Content is not allowed in Prolog (前言中不允许有内容)

    解析 XML 文件的时候,如 Mybatis 的 Mapper 文件,有时会出现 org.xml.sax.SAXParseException 前言中不允许有内容 的异常,英文就是 Content is ...

  9. 使用docker-compose创建启动容器时候提示服务名已存在

    今天在测试环境启动一个已有服务时候提示服务名已存在,造成这个原因是,前些天集群的一个节点挂了,导致这个节点上的docker容器全部没了,为了当时能正常使用就使用 docker-compose -H 1 ...

  10. T-SQL编程中的异常处理-异常捕获(try catch)与抛出异常(throw)

    本文出处: http://www.cnblogs.com/wy123/p/6743515.html T-SQL编程与应用程序一样,都有异常处理机制,比如异常的捕获与异常的抛出(try catch th ...