计算机算法分析与设计(23)---二分搜索算法(C++)

本文介绍了二分搜索算法的基本思想、比较过程,以及在C++中的实现。通过举例说明,展示了其在有序数组中的高效查找能力,特别指出时间复杂度为O(nlogn)。
摘要由CSDN通过智能技术生成


1. 算法介绍

 1. 二分搜索(英语:binary search),也称折半搜索(英语:half-interval search)、对数搜索(英语:logarithmic search),是用来在一个有序数组中查找某一元素的算法。

 2. 二分搜索算法基本思想是:将 n n n 个元素分成个数大致相同的两半,取 a [ n / 2 ] a[n/2] a[n/2] x x x 作比较。如果 x = a [ n / 2 ] x=a[n/2] x=a[n/2],则找到 x x x,算法终止;如果 x < a [ n / 2 ] x<a[n/2] x<a[n/2],则在数组 a a a 的左半部分继续搜索 x x x;如果 x > a [ n / 2 ] x>a[n/2] x>a[n/2],则在数组 a a a 的右半部分继续搜索 x x x

 3. 与普通查找比较验示,发现二分查找可以有效降低查找次数。

在这里插入图片描述

 4. 数组长度为奇数和偶数的情况,这里我们用最大角标来除。

在这里插入图片描述

在这里插入图片描述

2. 代码编写

n / 2 k = 1 n/2^k=1 n/2k=1,最坏经过 k k k 次二分之后找到目标值,所以时间复杂度为 O ( n l o g n ) O(nlogn) O(nlogn)(最坏)。

#include<iostream>
#include<algorithm>
using namespace std;
int n, x, a[105];
int bs(int left, int right, int x){
	int mid = (left + right) / 2;
	if (x < a[mid])
	{
		return bs(left, mid - 1, x);
	}
	else if (x > a[mid])
	{
		return bs(mid + 1, right, x);
	}
	else
	{
		return mid;
	}
}
int main(){
	cout<<"请输入元素个数:"<<endl;
	cin >> n ;
	cout<<"请输入数组元素:"<<endl;
	for (int i = 0; i < n; i++) {
		cin >> a[i];
	}
	cout<<"请输入查找元素:"<<endl;
	cin >> x;
	 
	sort(a,a+n);  //升序排列 
	cout<<"该查找元素在排序后数组中的角标为:"<<endl;
	cout << bs(0, n-1, x);
	return 0;
}

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冒冒菜菜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值