首页 > 其他 > 详细

查找与排序

时间:2014-08-11 17:18:42      阅读:253      评论:0      收藏:0      [点我收藏+]
#include <iostream>
using namespace std;
//二分查找算法实现
int BinarySearch(int a[],int len,int findnum)
{
    int low = 0;    
    int high = len - 1;    
    while(low <= high)    
    {        
        int middle = (low + high)/2;        
        if(a[middle] == findnum)            
        {
            return middle;
        }
        else if(a[middle] > findnum)            
        {
            high = middle - 1;
        }
        else 
        {
            low = middle + 1;
        }
    }       
    return -1;
}
void main()
{
    int a[]={1,3,6,8,9,11,55,77,88};
    int leng=sizeof(a)/sizeof(int);
    int low=0;
    int hig=leng-1;
    int mid=(hig+low)/2;
    cout<<"please input the number you want to find: ";
    int findnum=0;
    cin>>findnum;
    int iRet=BinarySearch(a,leng,findnum);
    if (iRet==-1)
    {
        cout<<"没找到";
    }
    else
        cout<<iRet;
}

 

查找与排序,布布扣,bubuko.com

查找与排序

原文:http://www.cnblogs.com/mu-tou-man/p/3904811.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!