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; // 返回-1表示未找到目标数
}

int main() {
    int arr[] = {2, 4, 6, 8, 10, 12, 14, 16, 18};
    int n = sizeof(arr) / sizeof(arr[0]);
    int target = 10;
    
    int result = binarySearch(arr, n, target);
    
    if (result != -1) {
        printf("目标数 %d 找到在索引 %d\n", target, result);
    } else {
        printf("目标数 %d 未找到\n", target);
    }
    
    return 0;
}

您可以将要查找的数组和目标数传递给binarySearch函数,并在函数返回的索引位置找到目标数。如果未找到目标数,则函数将返回-1。在上面的示例中,目标数10在数组中的索引3处找到。

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

推荐文章

  • c语言线程栈大小怎么设置合适

    在C语言中,线程的栈大小可以通过设置线程属性来进行调整。可以使用pthread_attr_init函数来初始化线程属性,然后使用pthread_attr_setstacksize函数来设置栈大小...

  • C语言结构体嵌套如何赋值

    在C语言中,结构体嵌套的赋值可以使用两种方式:点运算符和赋值运算符。 使用点运算符:
    结构体嵌套时,可以通过点运算符来访问内层结构体的成员,然后进行...

  • c语言enum的用法是什么

    在C语言中,enum(枚举)是一种用于定义一组具有相同数据类型的常量的方式。它可以提供一组代表有限集合的命名常量。以下是enum的用法: 定义枚举类型:使用enum...

  • c语言include的用法是什么

    在C语言中,include是一个预处理指令,用于将头文件包含到源代码中。它的语法格式为:
    #include header_file_name是要包含的头文件的名称,可以是标准库的头...

  • 怎么用C语言二分法求方程的根

    二分法是一种常用的数值计算方法,可以用来求解方程的根。下面是一个用C语言实现二分法求方程根的示例代码:
    #include #include // 定义方程的函数
    do...

  • linux查看硬盘序列号的方法是什么

    可以使用以下命令来查看硬盘序列号: 使用lsblk命令查看硬盘信息: lsblk -o NAME,SERIAL 使用hdparm命令查看硬盘序列号: sudo hdparm -I /dev/sdX | grep Seri...

  • mysql中timestamp类型怎么使用

    在 MySQL 中,TIMESTAMP 类型用于存储日期和时间。您可以使用 TIMESTAMP 类型来存储一个特定的日期和时间,例如创建时间或更新时间。
    要创建一个使用 TIMES...

  • layui怎么批量删除表格数据

    在layui中,可以通过以下步骤来实现批量删除表格数据: 在表格中添加一个复选框列来实现选择多条数据;
    为复选框列的每个复选框添加一个事件监听器,在复选...