网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

求旋转数组的最小值

思路:

成都创新互联是一家以网络技术公司,为中小企业提供网站维护、成都网站制作、网站设计、网站备案、服务器租用、主机域名、软件开发、成都微信小程序等企业互联网相关业务,是一家有着丰富的互联网运营推广经验的科技公司,有着多年的网站建站经验,致力于帮助中小企业在互联网让打出自已的品牌和口碑,让企业在互联网上打开一个面向全国乃至全球的业务窗口:建站欢迎来电:18982081108

基本方法:从头遍历一遍,时间复杂度为O(n),效率比较低,这里采用二分查找,找出中间元素与头,尾比较,如果中间元素比头元素大,说明这部分有序,最小值在后半部分,中间元素为头:如果中间元素比尾元素大,说明最小值在前部分。

  设定两个指针start和end分别指向数组的首尾元素,然后当start指向前半段最后一个元素,end指向后半段第一个元素,这是程序就找到了数组中的最小元素,就是end指向的那个数,程序的出口就是 end-start==1。

#include
#include
#include
int MinOrder(int* a,int n )
{
	int min=a[0];
	for(int i=1;ia[i])
		{
         min=a[i];
		}
	}
	return min;
}
int Min(int* a,int n)
{
	assert(a);
  int start=0;
  int end=n-1;
  while(a[start]>=a[end])
  {
	  if(end-start==1)  
	  {
		  return a[end];
	  }
	  int mid=(start+end)/2;
	  if(a[mid]==a[start]&&a[mid]==a[end]) //当下标为start,end,mid的数相同时,只能顺序访问。
	  {
		  return MinOrder( a,n);
	  }
	  if(a[start]<=a[mid])
	  {
		  start=mid;
	  }
	  else if(a[mid]<=a[end])
	  {
		  end=mid;
	  }

  }
  return a[start];
}
void test()
{
	int a1[5]={3,4,5,1,2};
	int ret1=Min(a1,sizeof(a1)/sizeof(a1[0]));
	printf("%d\n",ret1);

	int a2[5]={2,2,5,1,2};
	int ret2=Min(a2,sizeof(a2)/sizeof(a2[0]));
	printf("%d\n",ret2);


	int a3[5]={5,1,2,3,4};
	int ret3=Min(a3,sizeof(a3)/sizeof(a3[0]));
	printf("%d\n",ret3);

	int a4[5]={4,3,4,4,4};
	int ret4=Min(a4,sizeof(a4)/sizeof(a4[0]));
	printf("%d\n",ret4);

	int a5[5]={4,4,4,3,4};
	int ret5=Min(a5,sizeof(a5)/sizeof(a5[0]));
	printf("%d\n",ret5);
}
int main()
{
	test();
	system("pause");
	return 0;
}

结果:

求旋转数组的最小值


分享文章:求旋转数组的最小值
本文链接:http://bjjierui.cn/article/gsjdid.html

其他资讯