美团面试题:寻找数组置尾操作的最小值「建议收藏」

美团面试题:寻找数组置尾操作的最小值

大家好,又见面了,我是全栈君。

题目:

一个递增的整形数组,如今的操作是每次从数组的开头取出一个元素放在数组的末尾。连续n次这种操作后得到一个新的数组,

如今把这个数组给你,请求出最少移动的次数。

解析:

1 最easy想到的方法就是依次遍历这个数组,找到最小值的位置,这种时间复杂度就是O(n)。

2 考虑到事先是排好序的,所以我们能够使用二分查找法来实现这个操作,仅仅只是是这个二分查找法是传统二分查找法的变种。

这里我们仅仅要考虑下面3种情况。
<1>数组先递增再递减,中值大于左值,那么此时的最小值就处于数组的右半部。

<2>数组先递增再递减,中值小于左值,那么此时的最小值就处于数组的左半部。

<3>数组单调递增,此时的最小值就是数组的首元素。

3 程序实现
依据解析中2的思想,採取二分查找法的程序例如以下所看到的:

#include <iostream>
using namespace std;
int getInvertNumber(int arr[],int nLength);


void main()
{
	int arr[] = {1,2,3,4,5,6,7,8,9};
	int brr[] = {1,3,4,6,8,9};
	int sb = getInvertNumber(brr,sizeof(brr)/sizeof(brr[0]));
	cout<<sb<<endl;


}


int getInvertNumber(int arr[],int nLength)
{
	int nLeft = 0;
	int nRight = nLength-1;
	int nMid;
	if(arr[nLeft]<arr[nRight])
		return 0;
	while(nLeft<nRight)
	{
		nMid = ( nLeft + nRight ) / 2;
		if(arr[nMid]>arr[nLeft])
			nLeft = nMid;
		else
			nRight = nMid;
	}


	return nLength -nMid-1;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116511.html原文链接:https://javaforall.net

(0)
上一篇 2022年1月20日 下午1:00
下一篇 2022年1月20日 下午2:00


相关推荐

  • js判断类型

    js判断类型1 instanceof 运算符判断类型 functionAaa 父类 this name 小明 leta newAaa letstr newString asd letstr2 asdf letobj name 小明

    2026年3月19日
    2
  • 前端开发代码编辑器_前端自动生成代码

    前端开发代码编辑器_前端自动生成代码目录前言CodeSandbox介绍多种模板代码选择VSCode一致体验运行Node容器CodeSandbox示例前言有时候需要经常写一些测试代码或示例,然后将这些代码分享给他人,少量的代码通过GitHub分享有点大材小用,而且他人要从GitHub上fork代码后,在本地用IDE打开,然后安装依赖、运行,这个步骤过于繁琐。因此使用在线代码编辑器就能解决上面说到的问题,CodeSandbox介绍我用过几个在线代码编辑器,如知名的CodePen,Jsfilddle和Jsbin也有使用过,对比起来,还是C

    2022年8月14日
    10
  • 深入理解HashMap和TreeMap的区别

    深入理解HashMap和TreeMap的区别文章目录简介 HashMap 和 TreeMap 本质区别排序区别 Null 值的区别性能区别共同点深入理解 HashMap 和 TreeMap 的区别简介 HashMap 和 TreeMap 是 Map 家族中非常常用的两个类 两个类在使用上和本质上有什么区别呢 本文将从这两个方面进行深入的探讨 希望能揭露其本质 HashMap 和 TreeMap 本质区别先看 HashMap 的定义 publicclassH

    2026年3月19日
    3
  • php实现第三方登录

    php实现第三方登录

    2021年10月25日
    37
  • 微软发布 VS Code 1.107:Agent HQ 指挥中心登场,组团 AI 智能体为你写代码

    微软发布 VS Code 1.107:Agent HQ 指挥中心登场,组团 AI 智能体为你写代码

    2026年3月16日
    2
  • 学会使用getopt函数[通俗易懂]

    学会使用getopt函数[通俗易懂]简介getopt函数是命令行参数解析函数,在平时阅读源码的时候经常遇到,很有必要对其总结一下,做个记录!命令行参数各组成部分的名称先来了解下命令行参数各组成部分的名称。直接上图:非常清楚,命令行参数由Commandname,Option,Optionargument以及Operands组成。Commandname不用多说,就是程序的名称。操作对象Operands又…

    2022年6月9日
    50

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号