117.info
人生若只如初见

C语言如何实现二分查找算法

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

#include 

// 二分查找函数
int binarySearch(int arr[], int n, int target) {
    int left = 0;
    int right = n - 1;

    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; // 未找到目标元素
}

int main() {
    int arr[] = {1, 3, 5, 7, 9, 11, 13};

    int target = 7;
    int index = binarySearch(arr, 7, target);

    if (index != -1) {
        printf("目标元素 %d 在数组中的索引位置为 %d\n", target, index);
    } else {
        printf("未找到目标元素 %d\n", target);
    }

    return 0;
}

在这个示例中,通过 binarySearch 函数实现了二分查找算法,对一个已排序的数组进行查找。在 main 函数中,我们定义了一个数组 arr,并且指定了目标元素 target 进行查找。最后输出查找结果。

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

推荐文章

  • c语言goto用法是什么

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

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

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

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

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

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

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

  • 如何查看redis里的数据

    要查看Redis中的数据,可以使用以下几种方法: 使用Redis命令行客户端工具:可以通过在终端中输入redis-cli命令来启动Redis的命令行客户端工具。然后可以使用GET...

  • redis最大连接数如何看

    在Redis中,最大连接数取决于Redis配置文件中的maxclients参数。可以通过以下命令查看Redis的配置文件路径:
    redis-cli config get dir 然后可以通过编辑该...

  • sql如何删除表中重复项

    要删除表中的重复项,可以使用以下SQL语句:
    DELETE FROM table_name
    WHERE rowid NOT IN ( SELECT MIN(rowid) FROM table_name GROUP BY column1, co...

  • linux中怎么查看当前所在的文件路径

    在 Linux 中,你可以使用 `pwd` 命令来查看当前工作目录(即当前所在的文件路径)。以下是具体步骤:1. 打开终端。2. 输入 `pwd` 命令并按下回车键:```pwd```3....