c++详解二分查找

一.概念

对于区间[a,b]上连续不断且f(a)·f(b)<0的函数y=f(x),通过不断地把函数f(x)的零点所在的区间一分为二,使区间的两个端点逐步逼近零点,进而得到零点近似值的方法叫二分法

二.实现方案 

第一步:对数组进行升序排序。

#include<bits/stdc++.h>
using namespace std;
int main(){
	int a[10000];
	int n,FindValue;
	cin>>n>>FindValue;
	for(int i=0;i<n;i++){
		cin>>a[i];
	}
	sort(a,a+n);  
	return 0;
} 

第二步:定义一个函数叫binary_search,传入数组和要查找的数据。随后用双指针,一个在数组的第一项,一个在数组的第n项。在定义一个mid指向数组的中项。

#include<bits/stdc++.h>
using namespace std;
int n,FindValue;
int binary_search(int a[],int value){
	int left=0,right=n-1;//让left指向数组第一个位置,right指向数组的n-1位置。 
	int mid=(left+right)/2; //mid指向left和right的中间的项的位置。
	 
}
int main(){
	int a[10000];	
	cin>>n>>FindValue;
	for(int i=0;i<n;i++){
		cin>>a[i];
	}
	sort(a,a+n);
	return 0;
} 

第三步:编写结束条件,如果a[mid]==value就说明找到了,返回位置,也就是mid。

#include<bits/stdc++.h>
using namespace std;
int n,FindValue;
int binary_search(int a[],int value){
	int left=0,right=n-1;//让left指向数组第一个位置,right指向数组的n-1位置。 
	int mid=(left+right)/2; //mid指向left和right的中间的项的位置。
	if(a[mid]==value){ //如果找到了就输出value所在数组中的位置 
		return mid;
	} 
}
int main(){
	int a[10000];	
	cin>>n>>FindValue;
	for(int i=0;i<n;i++){
		cin>>a[i];
	}
	sort(a,a+n);
	return 0;
} 

第四步,也是最重要的一步:我们首先判断这个数是大于a[mid]还是小于a[mid],因为数组已经有序,如果大于说明a[mid]项以下包括a[mid]都不可能是value。因为a[mid]以下肯定比a[mid]项小。我们就不考虑mid项以下的情况了,就把left左指针更改为mid+1(mid不可能是我们找的那个数)。如果小于也是这样,把right指针移到mid-1;

#include<bits/stdc++.h>
using namespace std;
int n,FindValue;
int binary_search(int a[],int value) {
	int left=0,right=n-1;//让left指向数组第一个位置,right指向数组的n-1位置。
	int mid=(left+right)/2; //mid指向left和right的中间的项的位置。
	if(a[mid]==value) { //如果找到了就输出value所在数组中的位置
		return mid;
	}
	if(a[mid]>value) {//如果大于则移动left(左指针)到mid+1
		left=mid+1;
	}
	if(a[mid]<value) {//如果小于就移动right(右指针)到mid-1
		right=mid-1;
	}
}
int main() {
	int a[10000];
	cin>>n>>FindValue;
	for(int i=0; i<n; i++) {
		cin>>a[i];
	}
	sort(a,a+n);
	return 0;
}

最后一步,更新左范围和右范围。进行递归处理,函数的参数也要加,别忘了调用和输出。

#include<bits/stdc++.h>
using namespace std;
int n,FindValue;
int binary_search(int a[],int value,int x,int y) {
	int left=x,right=y;//让left指向数组第一个位置,right指向数组的n-1位置。
	int mid=(left+right)/2; //mid指向left和right的中间的项的位置。
	if(a[mid]==value) { //如果找到了就输出value所在数组中的位置
		return mid;
	}
	if(a[mid]>value) {
		left=mid+1;
	}
	if(a[mid]<value) {
		right=mid-1;
	}
	binary_search(a,value,left,right);//更新查找范围 
}
int main() {
	int a[10000];
	cin>>n>>FindValue;
	for(int i=0; i<n; i++) {
		cin>>a[i];
	}
	sort(a,a+n);
	cout<<binary_search(a,FindValue,0,n-1); //调用和输出 
	return 0;
}

完整代码:

#include<bits/stdc++.h>
using namespace std;
int n,FindValue;
int binary_search(int a[],int value,int x,int y) {
	int left=x,right=y;//让left指向数组第一个位置,right指向数组的n-1位置。
	int mid=(left+right)/2; //mid指向left和right的中间的项的位置。
	if(a[mid]==value) { //如果找到了就输出value所在数组中的位置
		return mid;
	}
	if(a[mid]>value) {
		left=mid+1;
	}
	if(a[mid]<value) {
		right=mid-1;
	}
	binary_search(a,value,left,right);//更新查找范围 
}
int main() {
	int a[10000];
	cin>>n>>FindValue;
	for(int i=0; i<n; i++) {
		cin>>a[i];
	}
	sort(a,a+n);
	cout<<binary_search(a,FindValue,0,n-1); //调用和输出 
	return 0;
}

推荐刷的二分好题:

【深基13.例1】查找

[蓝桥杯 2017 省 AB] 分巧克力

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值