二分查找及其时间复杂度-创新互联

二分查找又称折半查找,它是一种效率较高的查找方法。

班戈ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联建站的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:028-86922220(备注:SSL证书合作)期待与您的合作!

二分查找的思想:

 二分查找就是在一个有序的一维数组中找到想要找到的那个数key。先给出一个有序的一维数组,并表明想要找到的数,然后定义两个指针,一个指向数组的首地址left,一个指向数组的最后right,求出数组中间的下标mid=(left+right)/2,以mid为划分,如果key=arr[mid];找到了结束,如果key>arr[mid];

在arr[mid]+1到right中间找,并且将left指向arr[mid]+1,继续在left和right中间根据折半的方法查找,直到找到key结束。如果arr[mid]>key,在left和arr[mid]+1中间找,并且将right指向arr[mid]+1;

继续在left和right中间根据折半的方法查,直到找到结束。

#include <stdio.h>

int binsearch(int a[],int num, int len)
{
	int left = 0;
	int right = len-1;
	while(left <= right)
	{
		int mid = (left + right)/2;
		if (a[mid] == num)
		{
			return num;
		}
		else if(a[mid] > num)
		{
			right = mid-1;
		}
		else
		{
			left = mid + 1;
		}
	}
	return -1;
}

int main()
{
	int arr[] = {1,2,3,4,5,6,7,8,9};
	int key = 9;
    int sz = sizeof(arr)/sizeof(arr[0]);
	int ret = binsearch(arr,key,sz);
	if (ret == -1)
	{
		printf("无此数\n");
	}
	else
	{
		printf("%d",ret);
	}
	return 0;
}

时间复杂度为O(lgN);二分查找第一次分为两部分,第二次分为四部分,第三次八部分.....相当为一颗二叉树。

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。

分享名称:二分查找及其时间复杂度-创新互联
网页地址:https://www.cdcxhl.com/article2/dojeoc.html

成都网站建设公司_创新互联,为您提供品牌网站设计静态网站虚拟主机企业建站软件开发云服务器

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都网页设计公司