查找排序数组的最小值(js)

六月 北京 | 高性能计算之GPU CUDA培训

6月22-24日 640?wx_fmt=jpeg三天密集式学习  快速带你入门 阅读全文 >


正文共570个字,预计阅读时间5分钟。


题目


在由小到大已排序的未知数组中,以某个元素为支点旋转(好比将序列沿着前后顺序围成环移动)得到了一个数组,请找出该数组的最小值。比如倘若原数组(对我们而言,并不知道原数组是什么)为0,1,2,3,4,5,6,7,可能经过旋转后得到数组 3,4,5,6,7,0,1,2。请找出旋转后数组的最小值(假定数组中没有重复数字)。



答: Math.min(), 卒。。。


从旋转点分开的两段数组都是有序的,而且前面数组的值都要大于后边子数组的元素,所以要找的旋转后数组的最小值也就是两个有序数组的分界线。


记中间位置的元素arr[mid],开始元素arr[start],结尾元素arr[end].。如果arr[mid]>arr[start],则分界点必然在[mid, end];如果arr[mid]<arr[start],则分界点必然在[start, mid];循环往复。。。。


所以有点像数学中的夹逼准则,有两个指针分别从数组开头和结尾想目的地不断逼近,直到缩小的范围成为一个点,则是目标值。


 1function findMin(arr){
2let start=0;
3let end=arr.length-1;
4while(start<end){
5let mid=Math.floor((start+end)/2);
6// 当end-start==1时,mid==start
7if (arr[mid]>=arr[start]) {
8    // 对于原本升序的数组,arr[mid]不可能是最小值
9    start=mid+1
10}
11else {
12    // 对于原本升序的数组,此时arr[mid]有可能是最小值
13    end= mid
14}
15}
16return arr[start]
17}


题目本身并不难,但重要的是要找好边界条件,比如arr[mid]>=arr[start])还是>会对结果有什么影响?


原文链接:https://www.jianshu.com/p/80cfbe22f406


查阅更为简洁方便的分类文章以及最新的课程、产品信息,请移步至全新呈现的“LeadAI学院官网”:

www.leadai.org


请关注人工智能LeadAI公众号,查看更多专业文章

640?wx_fmt=jpeg

大家都在看

640.png?

LSTM模型在问答系统中的应用

基于TensorFlow的神经网络解决用户流失概览问题

最全常见算法工程师面试题目整理(一)

最全常见算法工程师面试题目整理(二)

TensorFlow从1到2 | 第三章 深度学习革命的开端:卷积神经网络

装饰器 | Python高级编程

今天不如来复习下Python基础

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值