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;
        }
    }
    
    // 当查找不到目标元素时,返回-1表示查找失败
    return -1;
}

int main() {
    int arr[] = {5, 10, 15, 20, 25, 30, 35, 40, 45, 50};
    int target = 30;
    int size = sizeof(arr) / sizeof(arr[0]);
    
    int result = binarySearch(arr, 0, size - 1, target);
    if (result == -1) {
        printf("目标元素 %d 未找到\n", target);
    } else {
        printf("目标元素 %d 在数组中的索引为 %d\n", target, result);
    }
    
    return 0;
}

运行以上代码,将输出 “目标元素 30 在数组中的索引为 5”,表示目标元素30在数组中的索引位置为5。如果目标元素不在数组中,则输出 “目标元素 30 未找到”。

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

推荐文章

  • c语言goto用法是什么

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

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

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

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

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

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

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

  • c语言如何实现数据的查找

    在C语言中,可以使用线性搜索、二分搜索、哈希表等方式实现数据的查找。 线性搜索:
    线性搜索是最简单的查找方法,它通过遍历数据集合中的每一个元素,逐个...

  • delphi中怎么调用api接口

    在Delphi中调用API接口的方法如下: 使用TIdHTTP组件发送HTTP请求: uses IdHTTP; procedure CallAPI;
    var HTTP: TIdHTTP; Response: string;
    begin H...

  • vb二分法查找数组元素怎么实现

    在VB语言中,可以使用以下代码来实现二分法查找数组元素:
    Function BinarySearch(arr() As Integer, target As Integer) As Integer Dim left As Integer ...

  • java循环输出不换行怎么实现

    在Java中,可以使用System.out.print()方法来输出不换行的内容。例如,要循环输出数字1到10,可以使用如下代码:
    for (int i = 1; i