题目描述

把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{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. AES-128-CBC C语言代码

    /** * Copyright (c) 2007, Cameron Rich * * All rights reserved. * * Redistribution and use in source ...

  2. delphi 动态绑定代码都某个控件

    delphi 动态绑定代码都某个控件 http://docwiki.embarcadero.com/CodeExamples/Berlin/en/Rtti.TRttiType_(Delphi)Butt ...

  3. 【JEECG技术文档】JEECG 组织机构导入V3.7

    1.功能介绍 组织机构导入 提供组织机构模版导入功能,使用户更快速的创建组织机构 要使用组织机构导入功能需要完成以下步骤: 1. 下载模版excel 2. 填写组织机构信息 3. 点击导入-选择文件- ...

  4. ORM 的基本操作

    https://www.cnblogs.com/sss4/p/7070942.html

  5. 服务发现 - consul 的介绍、部署和使用(转)

    什么是服务发现 相关源码: spring cloud demo 微服务的框架体系中,服务发现是不能不提的一个模块.我相信了解或者熟悉微服务的童鞋应该都知道它的重要性.这里我只是简单的提一下,毕竟这不是 ...

  6. upupw

    https://sourceforge.net/projects/upupw/files/ANK/

  7. Unable to connect to zookeeper server within timeout: 5000

    错误 严重: StandardWrapper.Throwable org.springframework.beans.factory.BeanCreationException: Error crea ...

  8. unity Flash Animation Toolset插件使用

    插件网站:http://matov.me/flash-animation-toolset/ 1.在unity上打开资源商店,Window -> Asset Store -> 搜索Flash ...

  9. How to Pronounce Numbers 20 – 1 Billion

    How to Pronounce Numbers 20 – 1 Billion Share Tweet Share Tagged With: Numbers Numbers are something ...

  10. ReactiveX 学习笔记(15)使用 Rx.NET + Json.NET 调用 REST API

    JSON : Placeholder JSON : Placeholder (https://jsonplaceholder.typicode.com/) 是一个用于测试的 REST API 网站. ...