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;
        }

        // 目标值在右半边
        if (arr[mid] < target) {
            left = mid + 1;
        }
        // 目标值在左半边
        else {
            right = mid - 1;
        }
    }

    // 没有找到目标值
    return -1;
}

int main() {
    int arr[] = {1, 2, 3, 4, 5, 6, 7, 8, 9};
    int target = 6;
    int n = sizeof(arr) / sizeof(arr[0]);

    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 函数实现了二分法查找算法。它通过传入的参数 leftright 来确定当前查找范围的左右边界,然后通过计算中间位置 mid 来确定需要查找的值在左半边还是右半边。如果找到目标值,就返回其索引;如果没有找到目标值,就返回 -1。

main 函数中,我们定义了一个有序数组 arr,并设定了目标值 target。然后,我们调用 binarySearch 函数来查找目标值在数组中的索引,并根据返回结果进行输出。

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

推荐文章

  • c语言goto用法是什么

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

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

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

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

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

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

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

  • c语言中合并两个数组的方法是什么

    在C语言中,可以通过使用循环遍历的方法合并两个数组。具体步骤如下: 定义三个数组:第一个数组用来存放合并后的结果,第二个数组和第三个数组分别存放要合并的...

  • vb字符串怎么转字节数组

    在VB中,可以使用Encoding类的GetBytes方法将字符串转换为字节数组。以下是一个示例代码:
    Imports System.Text Module Program Sub Main() Dim str As Str...

  • dubbo怎么限制并发数

    在Dubbo中,可以通过配置或标签的executes属性来限制并发数。
    具体配置如下: 上述例子中,executes属性的值表示并发执行的线程数,这会影响服务提供者和消...

  • java多线程共享数据怎么实现

    在Java中,可以通过以下几种方式实现多线程共享数据: 使用共享变量:多个线程访问和修改同一个共享变量。在使用共享变量时需要注意线程安全性,可以使用synchro...