2021-08-03二分查找

#include <stdio.h>
int BinarySearch(int* Nums, int Size, int Left, int Right, int Target);
void test(void);
int main()
{
  test();
  return 0;
}
void test(void) {
  int a[10] = { 3,7,14,17,17,23,27,29,45,67 };
  int find=BinarySearch(a, 10, 0, 9, 23);
  printf("%d\n", find);
   find = BinarySearch(a, 10, 0, 9, 3);
   printf("%d\n", find);
  find = BinarySearch(a, 10, 0, 9, 67);
  printf("%d\n", find);

}
int BinarySearch(int* Nums, int Size, int Left, int Right, int Target) {
  int L = Left; int R= Right;
  while (L<=R)
  {
  int mid = (L + R) / 2;
  if (Nums[mid] == Target)
      return mid;
  else if (Nums[mid] > Target) {
  R=mid-1;
  }
  else {
      L=mid+1;
  }
     }
  if (L > R)return -1;

}

运行结果:
image.png

容易错的地方,R=mid-1,L=mid+1
假设有个数组a[3,5,7],查找7;第一次L=0,R=2,mid=1,a[1]=5,5<7;
第二次查找,如果让L=mid=1,在[5,7]内查找,那这次的mid=(1+2)/2=1,就会找不到

循环条件为什么是L<=R,二分查找分到最后可能会剩一个元素,这时 L=R;

如果最后那次(L=R)循环还没找到,不管R=mid-1还是L=mid+1(这里的mid=L=R),都会让L>R,返回-1表示没有找到

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 模板原地址,从大佬那里习得的另一位的解析,下面有更具体的分析模板一共有两种,适用于两种不同的情况,第一种是: 我们...
    Charon_ted阅读 3,783评论 0 0
  • 1 前言 二分查找本身是个简单的算法,但是正是因为其简单,更容易写错。甚至于在二分查找算法刚出现的时候,也是存在b...
    __七把刀__阅读 5,295评论 0 1
  • 针对序列已经排好序了,以从小到大排好的序列为例,每次取中间的元素和待查找的元素比较,如果中间的元素比待查找的元素小...
    mysimplebook阅读 734评论 0 0
  • 前言 一般用符号表来储存键值对,就好像字典那样,通过索引来查找值,若键重复则覆盖值。我们能希望找到一种高效的查找算...
    传奇内服号阅读 5,283评论 0 0
  • 二分查找是面试常考的知识点,其方法是在有序序列中寻找满足特定条件的值,存在许多不同的变种,最近在刷Leetcode...
    喵帕斯0_0阅读 3,244评论 0 1