码迷,mamicode.com
首页 > Windows程序 > 详细

二分查找-while(C#)

时间:2019-12-17 23:58:53      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:middle   bsp   ati   ret   res   线性表   arch   turn   while   

 

 

//测试代码

int[] array = { 10, 20, 30, 40, 50, 60, 70, 80, 90 };
int result = BinarySearch(array, 55);
Console.WriteLine(result);

//只能查找有序的线性表
static int BinarySearch(int[] array, int key)
{
  int left = 0;
  int right = array.Length - 1;
  while (left <= right)
  {
    if (key == array[left])
      return array[left];
    if (key == array[right])
      return array[right];

    int middle = (left + right) / 2;
    if (key == array[middle])
      return array[middle];
    else if (key > array[middle])
      left = middle + 1;
    else
      right = middle - 1;
    }
    return -1;
    }
  }
}

二分查找-while(C#)

标签:middle   bsp   ati   ret   res   线性表   arch   turn   while   

原文地址:https://www.cnblogs.com/LZHOO97/p/12057517.html

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