117.info
人生若只如初见

c语言二分查找算法代码怎么写

以下是一个用C语言编写的二分查找算法代码示例:

#include 

// 二分查找函数
int binarySearch(int arr[], int left, int right, int target) {
    while (left <= right) {
        int mid = left + (right - left) / 2; // 中间元素的索引
        if (arr[mid] == target) {
            return mid; // 找到目标元素,返回索引
        } else if (arr[mid] < target) {
            left = mid + 1; // 目标元素在右侧,更新左边界
        } else {
            right = mid - 1; // 目标元素在左侧,更新右边界
        }
    }
    return -1; // 没有找到目标元素,返回-1
}

int main() {
   int arr[] = {2, 4, 6, 8, 10, 12, 14, 16, 18, 20};
   int n = sizeof(arr) / sizeof(arr[0]); // 数组长度
   int target = 12; // 目标元素
   int result = binarySearch(arr, 0, n - 1, target);
   if (result == -1) {
       printf("目标元素 %d 不存在\n", target);
   } else {
       printf("目标元素 %d 的索引为 %d\n", target, result);
   }
   return 0;
}

这个示例中,我们定义了一个binarySearch函数,该函数接受一个已经排序的整数数组arr、左边界left、右边界right和目标元素target作为参数。函数使用while循环来不断缩小搜索范围,直到找到目标元素或搜索范围为空。如果找到目标元素,返回其索引;否则返回-1表示未找到。

main函数中,我们定义了一个已经排序的整数数组arr,并使用sizeof运算符计算出数组的长度n。我们指定目标元素为12,并调用binarySearch函数进行查找。最后根据返回结果输出查找结果。

未经允许不得转载 » 本文链接:https://www.117.info/ask/fe407AzsLAgRSDVc.html

推荐文章

  • c语言goto用法是什么

    在C语言中,goto语句用于从一个位置跳转到另一个位置。它可以用于跳出循环、条件语句或者函数。goto语句的语法如下:
    goto label;
    ...
    label: //...

  • goto在c语言中的运用方法是什么

    goto 语句在 C 语言中允许程序从一个位置跳转到另一个位置。然而,在实际编程中,过度使用 goto 语句通常被认为是一种不好的编程实践,因为它可能导致代码结构混...

  • c语言堆和栈的区别是什么

    C语言中的堆和栈是两种不同的内存分配方式。 栈(Stack):栈是由编译器自动分配和释放的内存区域,用于存储局部变量和函数调用的上下文信息。栈的特点是先进后出...

  • C语言结构体数组怎么定义和使用

    在C语言中,可以通过定义结构体数组来存储多个具有相同数据类型的结构体对象。下面是定义和使用结构体数组的示例代码:
    #include // 定义一个结构体类型

  • delphi中嵌入脚本语言的方法是什么

    在Delphi中,可以通过使用TDelphiWebScript组件来嵌入脚本语言。以下是使用TDelphiWebScript组件嵌入脚本语言的基本步骤: 在Delphi中创建一个新的VCL Forms应用...

  • druid连接池配置的步骤是什么

    配置Druid连接池的步骤如下:1. 添加Druid依赖:在项目的构建文件(例如`pom.xml`)中添加所需的Druid连接池依赖,以确保能够在项目中使用Druid。以下是Maven项目...

  • golang多线程共享变量的方法是什么

    在Golang中,可以使用goroutine和channel来实现多线程共享变量。 使用goroutine和channel: 使用goroutine创建多个线程,每个线程可以并发执行。
    使用chann...

  • dubbo线程池的工作原理是什么

    Dubbo 是一个分布式服务框架,它的线程池是用来处理请求的。Dubbo 的线程池工作原理如下: 提供者端首先会创建一个线程池,用来处理接收到的客户端请求。这个线程...