二分查找(折半查找)
数据必须先排序,排序之后才能进行二分查找
220=100万(就是1M)
230=10亿(就是1G)
二分查找速度非常快
#include<iostream>
using namespace std;
int BinarySearch(int *a, const int x, const int n);
int main(){
int x[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
int 结果;
int num;
num = 1;
结果 = BinarySearch(x, num, 10);
if (结果 < 0)
cout << "没有找到!" << endl;
else
cout << "在x[" << 结果 << "]中找到" << num << endl;
system("pause");
return 0;
}
int BinarySearch(int *a, const int x, const int n){
int low, high, mid;
low = 0, high = n - 1;
while (low <= high){
mid = (low + high) / 2;
if (a[mid] == x)
return mid;
else if (a[mid] < x)
low = mid + 1;
else
high = mid - 1;
}
return -1;
}
使用下面的函数也是可以的。
int BinSearch(int *a, const int x, const int n){
int left = 0, right = n-1;
while(left<=right){
int middle = (left+right)/2;
if(x < a[middle])right = middle - 1;
else if (x > a[middle])left = middle + 1;
else return middle;
}
return -1;
}
总结:二分查找算是计算机里面最快的查找方法。但是对数据的要求是数据已经排序。数据没有排序就只能顺序查找。
本文介绍了二分查找(折半查找)的基本概念及其实现方法,强调了数据预先排序的重要性,并提供了两个C++实现示例。
2592

被折叠的 条评论
为什么被折叠?



