博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
二分查找实现
阅读量:4516 次
发布时间:2019-06-08

本文共 1133 字,大约阅读时间需要 3 分钟。

 

  1.  #include <iostream>  
  2.   
  3. using namespace std;  
  4.   
  5. /* 
  6. *二分查找思想:1、数组从小到大排序;2、查找的key每次和中间数比较,如果key小于mid 
  7. 查找mid左侧的数组部分;如果key大于mid,则查找mid右侧的数组部分;如果相等,则直接返回mid。 
  8.  
  9. 输入:排序数组-array,数组大小-aSize,查找值-key 
  10. 返回:返回数组中的相应位置,否则返回-1 
  11. */  
  12. //非递归查找  
  13. int BinarySearch(int *array, int aSize, int key)  
  14. {  
  15.     if ( array == NULL || aSize == 0 )  
  16.         return -1;  
  17.     int low = 0;  
  18.     int high = aSize - 1;  
  19.     int mid = 0;  
  20.   
  21.     while ( low <= high )  
  22.     {  
  23.         mid = (low + high )/2;  
  24.           
  25.         if ( array[mid] < key)  
  26.             low = mid + 1;  
  27.         else if ( array[mid] > key )     
  28.             high = mid - 1;  
  29.         else  
  30.             return mid;  
  31.     }  
  32.     return -1;  
  33. }  
  34. //递归  
  35. int BinarySearchRecursive(int *array, int low, int high, int key)  
  36. {  
  37.     if ( low > high )  
  38.         return -1;  
  39.     int mid = ( low + high )/2;  
  40.       
  41.     if ( array[mid] == key )  
  42.         return mid;  
  43.     else if ( array[mid] < key )  
  44.         return BinarySearchRecursive(array, mid+1, high, key);  
  45.     else  
  46.         return BinarySearchRecursive(array, low, mid-1, key);  
  47. }  
  48.   
  49. int main()  
  50. {  
  51.     int array[10];  
  52.     for (int i=0; i<10; i++)  
  53.         array[i] = i;  
  54.   
  55.     cout<<"No recursive:"<<endl;  
  56.     cout<<"position:"<<BinarySearch(array, 10, 6)<<endl;  
  57.     cout<<"recursive:"<<endl;  
  58.     cout<<"position:"<<BinarySearchRecursive(array, 0, 9, 6)<<endl;  
  59.   
  60.     return 0;  

转载于:https://www.cnblogs.com/xiaoxiong0222/p/4491527.html

你可能感兴趣的文章
需求文档中容易出的错误
查看>>
算法训练 安慰奶牛
查看>>
poj1426_kuagnbin带你飞专题一
查看>>
安装关系型数据库MySQL 安装大数据处理框架Hadoop
查看>>
软件定义网络(SDN)研究进展
查看>>
NOI2019 SX 模拟赛 no.5
查看>>
lambda表达式
查看>>
Delphi中使用DirectX截屏函数
查看>>
给内联元素设置宽高的几种方式
查看>>
Linux下定时切割Mongodb数据库日志并删除指定天数前的日志记录(转)
查看>>
MariaDB -- 数据类型
查看>>
JS 学习笔记--8---Function类型
查看>>
进程环境
查看>>
Clean Code 《代码整洁之道》前四章读书笔记
查看>>
jQuery中$.get()、$.post()和$.ajax()
查看>>
const char *p;和char * const p的区别
查看>>
此博客不再更新,新博客地址https://xsamsara.tk/
查看>>
万以内的字符串整数变成汉子字符串
查看>>
给网页添加跟随你鼠标移动的线条动画
查看>>
那些实用的Nginx规则
查看>>