码迷,mamicode.com
首页 > 其他好文 > 详细

准确实现二分查找方法

时间:2014-12-10 12:38:19      阅读:196      评论:0      收藏:0      [点我收藏+]

标签:二分查找   程序实现   移位算法   更新   

准确实现二分查找方法

    

    准确写出二分查找法很重要,因为其中有许多地方容易出错。


    主要有下面几点:

  • right初始值为num-1;
  • 每次更新right=middle-1; 
  • 每次更新middle为left+((right-left)>>1);  注意使用移位,以及移位运算符加括号!


正确的程序如下:


#include<iostream>
using namespace std; 

int isFinded(int *a, int num, int value)
{
	int left=0, right=num-1; 
	int middle; 

	while(left<=right)
	{
		middle=left+((right-left)>>1); 
		if(a[middle] < value)
			left=middle+1; 
		else if(a[middle] > value)
			right=middle-1; 
		else
			return middle;  //返回找到的位置
	}

	return -1;  //没找到
}

int main()
{
	int a[5]={1, 3, 5, 7, 9}; 
	int num=5; 
	int value=5; 

	int finded=isFinded(a, num, value); 

	cout<<finded<<endl;
	return 0; 
}


准确实现二分查找方法

标签:二分查找   程序实现   移位算法   更新   

原文地址:http://blog.csdn.net/puqutogether/article/details/41843937

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!