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语言数列如何表示

    在C语言中,数列可以使用数组(Array)来表示。数组是一种存储多个相同类型的元素的数据结构。
    要表示一个数列,首先需要确定数列的元素类型,例如整数型(...

  • C语言怎么用for循环实现斐波那契数列

    C语言中可以使用for循环来实现斐波那契数列,具体的实现方法如下:
    #include int main() { int n, i; int fib[20]; // 假设需要输出前20个斐波那契数列的数...

  • C语言怎么求斐波那契数列前n项值

    C语言中,可以使用循环或递归的方式来求斐波那契数列的前n项值。 使用循环的方式: #include void fibonacci(int n) { int i, t1 = 0, t2 = 1, nextTerm; printf...

  • c语言输出二维数组的方法是什么

    在C语言中,可以使用嵌套的for循环来输出二维数组。
    以下是一个示例程序:
    #include #define ROWS 3
    #define COLS 4 int main() { int arr[ROWS]...

  • 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