A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© skywan 中级黑马   /  2015-7-21 19:34  /  413 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

输入一个有序的数组,查找key=10的mid值
  1. int zheban(int a[], int len,int key){
  2.         //先定义变量
  3.         int low = 0, high = len - 1, mid;
  4.         //循环
  5.         while (low <= high)
  6.         {
  7.                 //计算mid是位置
  8.                 mid = (low+high)/2;
  9.                 //key>a[mid] low=mid+1; key<a[mid] high=mid-1; key>a[mid]  return mid;
  10.                 if (key > a[mid]){ low = mid + 1; }
  11.                 else if (key<a[mid])
  12.                 {
  13.                         high = mid - 1;
  14.                 }
  15.                 else
  16.                 {
  17.                         return mid;
  18.                 }
  19.                
  20.         }
  21.         return -1;
  22. }
  23. int main(int argc, char *argv[])
  24. {
  25.        
  26.         int a[8] = { 3, 4, 10, 58, 69, 78, 85, 92 };
  27.         int s= zheban(a, 8,10);//把数已经排序完
  28.                 printf("%d  ", s);
  29.         return 0;
  30. }
复制代码

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马