C语言:写一个函数,实现一个整型有序数组的二分查找

简介: 思路:总体思路:(一)自定义函数部分: (1).参数:

思路:

总体思路:

(一)自定义函数部分:

               

(1).

参数:

int arr[] -- 数组首地址


int k -- 要在数组中找的数字


int sz -- 数组长度


           


定义左右下标;


               


(2).


使用二分查找法;


           


(二)主函数部分:


       


定义有序数组,设置要查找的值,求出数组元素个数。


           


调用自定义函数。


           


判断自定义函数的返回值,打印相应的情况。

自定义函数部分:

第一步:

(1). 形参的设置:

int arr[] -- 数组首地址

int k -- 要在数组中找的数字

int sz -- 数组长度

(2). 定义左右下标 -- left right

                   

实现代码:

#include <stdio.h>
int binary_search(int arr[], int k, int sz)//形参
{
  int left = 0; //左下标
  int right = sz - 1; //右下标
}
int main()
{
  return 0;
}


实现图片:


ca47ada73ebc40078bfb31de46ce1772.png

第二步:

使用二分查找方法

       

(1). 使用while循环

         

(2). 生成中间值下标 mid

int mid = left + (right - left) / 2;


left 是 小的一边,(right - left)是两者的差值,(right - left)/ 2 是差值的一半,


left + (right - left) / 2,即 小的一边 加上 差值的一半,


这时 两边是一样的,任意一边都是平均值(中间值)


           


(3).


如果中间值 小于 要找的值,


舍弃中间值和中间值左边的所有数,调整 左下标left :left = mid + 1。


如果中间值 大于 要找的值,


舍弃中间值和中间值右边的所有数,调整 右下标right :right = mid - 1。


如果中间值 等于 要找的值,


返回中间值下标mid。


           


(4). 找不到则返回 -1 。

实现代码:

int binary_search(int arr[], int k, int sz)//形参
{
  int left = 0; //左下标
  int right = sz - 1; //右下标
  //使用while循环
  while (left <= right)
  {
    //生成中间值下标 mid :
    int mid = left + (right - left) / 2;
    //二分查找:
    if (arr[mid] < k)//中间值 小于 要找的值
    {
      left = mid + 1;
      //舍弃中间值和中间值左边的所有数,
      //调整 左下标left :left = mid + 1。
    }
    else if (arr[mid] > k)//中间值 大于 要找的值
    {
      right = mid - 1;
      //舍弃中间值和中间值右边的所有数,
      //调整 右下标right :right = mid - 1。
    }
    else if (arr[mid] == k)//中间值 等于 要找的值
    {
      return mid;
      //返回中间值下标mid。
    }
  } 
  if (left > right)
  {
    return -1; //找不到则返回-1
  }
}

实现图片:


632735d2c9734c3ba3688f5a9ba34059.png

主函数部分:

(1). 定义有序数组,设置要查找的值,求出数组元素个数

             

(2). 调用自定义函数

3). 判断自定义函数返回值打印相应的情况

                   

实现代码:

#include <stdio.h>
int binary_search(int arr[], int k, int sz)//形参
{
  int left = 0; //左下标
  int right = sz - 1; //右下标
  //使用while循环
  while (left <= right)
  {
    //生成中间值下标 mid :
    int mid = left + (right - left) / 2;
    //二分查找:
    if (arr[mid] < k)//中间值 小于 要找的值
    {
      left = mid + 1;
      //舍弃中间值和中间值左边的所有数,
      //调整 左下标left :left = mid + 1。
    }
    else if (arr[mid] > k)//中间值 大于 要找的值
    {
      right = mid - 1;
      //舍弃中间值和中间值右边的所有数,
      //调整 右下标right :right = mid - 1。
    }
    else if (arr[mid] == k)//中间值 等于 要找的值
    {
      return mid;
      //返回中间值下标mid。
    }
  } 
  if (left > right)
  {
    return -1; //找不到则返回-1
  }
}
int main()
{
  int arr[] = { 1,2,3,4,5,6,7,8,9,10 }; //定义有序数组
  int k = 7; //设置要查找的值
  int sz = sizeof(arr) / sizeof(arr[0]); //求出数组元素个数
  // 整个数组大小 / 单个数组元素大小 = 数组元素个数
  //调用自定义函数:
  int ret = binary_search(arr, k, sz); //ret接收返回的下标
  //判断自定义函数的返回值,打印相应的情况:
  if (ret == -1) //未找到,返回-1
  {
    printf("找不到\n");
  }
  else
  {
    printf("找到了,下标是:%d\n", ret);
  }
  return 0;
}

实现图片:

image.png

最终代码和实现效果

最终代码:

#include <stdio.h>
int binary_search(int arr[], int k, int sz)//形参
{
  int left = 0; //左下标
  int right = sz - 1; //右下标
  //使用while循环
  while (left <= right)
  {
    //生成中间值下标 mid :
    int mid = left + (right - left) / 2;
    //二分查找:
    if (arr[mid] < k)//中间值 小于 要找的值
    {
      left = mid + 1;
      //舍弃中间值和中间值左边的所有数,
      //调整 左下标left :left = mid + 1。
    }
    else if (arr[mid] > k)//中间值 大于 要找的值
    {
      right = mid - 1;
      //舍弃中间值和中间值右边的所有数,
      //调整 右下标right :right = mid - 1。
    }
    else if (arr[mid] == k)//中间值 等于 要找的值
    {
      return mid;
      //返回中间值下标mid。
    }
  } 
  if (left > right)
  {
    return -1; //找不到则返回-1
  }
}
int main()
{
  int arr[] = { 1,2,3,4,5,6,7,8,9,10 }; //定义有序数组
  int k = 7; //设置要查找的值
  int sz = sizeof(arr) / sizeof(arr[0]); //求出数组元素个数
  // 整个数组大小 / 单个数组元素大小 = 数组元素个数
  //调用自定义函数:
  int ret = binary_search(arr, k, sz); //ret接收返回的下标
  //判断自定义函数的返回值,打印相应的情况:
  if (ret == -1) //未找到,返回-1
  {
    printf("找不到\n");
  }
  else
  {
    printf("找到了,下标是:%d\n", ret);
  }
  return 0;
}

实现效果:

497f92bf06d044298e2f7feeb0614560.png

相关文章
|
2天前
|
C语言
C语言5 字符输出函数和格式输出函数
C语言5 字符输出函数和格式输出函数
6 1
|
4天前
|
算法 编译器 C语言
深入浅出C语言—【函数】下
深入浅出C语言—【函数】下
|
15天前
|
Java C语言 C++
定义C语言的int main()函数
定义C语言的int main()函数
|
17天前
|
存储 移动开发 C语言
技术心得记录:嵌入式开发中常用到的C语言库函数
技术心得记录:嵌入式开发中常用到的C语言库函数
11 1
|
2天前
|
存储 C语言
C语言6 字符串输入和格式输入函数
C语言6 字符串输入和格式输入函数
7 0
|
17天前
|
Java 程序员 Linux
探索C语言宝库:从基础到进阶的干货知识(类型变量+条件循环+函数模块+指针+内存+文件)
探索C语言宝库:从基础到进阶的干货知识(类型变量+条件循环+函数模块+指针+内存+文件)
19 0
|
17天前
|
C语言
C语言实现猜数字游戏:代码详解与函数解析
C语言实现猜数字游戏:代码详解与函数解析
12 0
|
17天前
|
程序员 C语言
C语言内存管理:malloc、calloc、realloc与free函数详解
C语言内存管理:malloc、calloc、realloc与free函数详解
13 0
|
18天前
|
C语言
C语言中的函数指针、指针函数与函数回调
C语言中的函数指针、指针函数与函数回调
11 0
|
18天前
|
存储 C语言
C语言中的变量与函数详解
C语言中的变量与函数详解
8 0