当前位置: 首页 > article >正文

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

文章目录

  • 1. 算法介绍
  • 2. 代码编写


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. 代码编写

#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;
}

在这里插入图片描述


http://www.kler.cn/a/136256.html

相关文章:

  • 设计模式 -- 建造者模式(Builder Pattern)
  • 广州华锐互动VRAR | VR课件内容编辑器解决院校实践教学难题
  • 中贝通信-603220 三季报分析(20231120)
  • 【python】直方图正则化详解和示例
  • Fourier分析导论——第6章——R^d 上的Fourier变换(E.M. Stein R. Shakarchi)
  • 【C++】使用std::vector()函数实现矩阵的加、减、点乘、点除等运算
  • 【腾讯云 HAI域探秘】高性能服务器引领AI革新浪潮:从AI绘画、知识问答到PyTorch图像分类、视频检测的全方位探索
  • React 中 react-i18next 切换语言( 项目国际化 )
  • mysql5.6 修改密码
  • Nosql之redis概述及基本操作
  • C++二分算法:找到最接近目标值的函数值
  • 用css实现原生form中radio单选框和input的hover已经focus的样式
  • DRF纯净版项目搭建和配置
  • ExcelBDD PHP Guideline
  • 从0开始学习JavaScript--JavaScript使用Promise
  • 虹科示波器 | 汽车免拆检修 | 1994款凯迪拉克fleetwood车发动机无法起动
  • 论文阅读:“iOrthoPredictor: Model-guided Deep Prediction of Teeth Alignment“
  • 访问限制符说明面向对象的封装性
  • 【ArcGIS Pro微课1000例】0033:ArcGIS Pro处理cad数据(格式转换、投影变换)
  • leetcode做题笔记2736. 最大和查询