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语言二维数组指针的特点是什么

    二维数组指针实际上是一个指向一维数组的指针,其类型为指向数组的指针的指针。
    可以通过二维数组指针来访问二维数组中的元素,其用法类似于通过二维数组名...

  • C语言数组输入多个数字怎么实现

    要实现输入多个数字到数组中,可以使用循环结构来读取用户输入的数字,并将其存储到数组中。以下是一个示例代码:
    #include int main() { int n; printf("请...

  • c语言菱形打印的方法是什么

    在C语言中,可以使用循环嵌套来实现菱形打印。下面是一个示例代码:
    #include int main() { int n, c, k, space = 1; printf("Enter number of rows: "); s...

  • c语言二维数组指针如何定义

    二维数组指针的定义方式如下:
    int (*ptr)[n]; 其中,ptr是一个指向n个整型元素的一维数组的指针。这样定义后,ptr指向了一个二维数组的第一行。通过ptr可以...

  • 如何查看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....