二分查找

简介: 二分查找
#include <stdio.h>
int main()
{
  int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
  int k = 4;
  int sz = sizeof(arr) / sizeof(arr[0]);  //计算元素个数
  int left = 0;
  int right = sz - 1;
  while (left <= right)
  {
    int mid = (left + right) / 2;
    if (arr[mid] > k)
    {
      right = mid - 1;
    }
    else if (arr[mid] < k)
    {
      left = mid + 1;
    }
    else
    {
      printf("找到了,下标是%d\n",mid);
      break;
    }
    if (left > right)
      printf("找不到");
  }
  return 0;
}

k=4

image.png

k=14

image.png


相关文章
|
算法 索引
二分查找(详解)
二分查找(详解)
|
8月前
|
算法 索引
二分查找(二)
二分查找(二)
|
8月前
|
算法 索引
二分查找(一)
二分查找(一)
|
8月前
|
算法 C++
C++021-C++二分查找
C++021-C++二分查找
C++021-C++二分查找
|
算法 C语言
这就是二分查找?
本文通过简单的猜数字小游戏向大家介绍二分查找的基本原理。
130 2
|
算法 索引
【二分查找】
【二分查找】
|
存储 算法
6-2 二分查找
6-2 二分查找
189 0
二分查找。
查找的数据必须是有序的。
87 0
二分查找。