您的位置:首页 > 其它

分治-二分查找

2016-04-16 13:30 393 查看
二分查找是最基本的分治思想

template<class Type>
int BinarySearch(Type a[], const Type& x, int n){//对一个有序列表进行二分查找
int left = 0;
int right = n-1;
while(left <= right){
int middle = (left + right) / 2;
if(x == a[middle])
return middle;
if(x > a[middle])       //大于二分的中位数,则以中位数下一位为最左位
left = middle + 1;
else                    //小于二分的中位数,则以中位数前一位为最右位
right = middle - 1;
}
return -1;      //未找到-1
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  算法 分治 查找