一.概念
对于区间[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;
}
推荐刷的二分好题: