c - 我的二进制搜索实现有什么问题?

标签 c binary-search

#include <stdio.h>
int bsearch(int a[], int n, int lo, int hi) {
    int mid;
    mid = (hi + lo) / 2;
    if(a[mid] == n)
        return 1;
    else if(a[mid] > n)
        bsearch(a, n, lo, mid);
    else
        bsearch(a, n, mid, hi);
    return 0;
} 

int main(void) {
    int n, a[7] = {2, 4, 5, 67, 70, 80, 81};
    int hi = 6, lo = 0, j;
    scanf("%d", &n);
    j = bsearch(a, n, lo, hi);
    if(j)
        printf("Found");
    else
        printf("Not Found"); 
    return 0;
 }

input : 5 output: Not Found

谁能告诉我为什么会得到这个结果?

最佳答案

您需要解决几个大问题才能使其正常工作(请参阅以下代码注释中的详细信息)。

将您的二进制搜索函数更改为以下内容:

int bsearch(int a[], int n, int lo, int hi)
{
    // add base case
    if (high < low)  
        return 0; // not found 

    int mid;
    mid=(hi+lo)/2;
    if(a[mid]==n)
        return 1;
    else if(a[mid]>n)
        return bsearch(a,n,lo,mid-1); // add return
    else
        return bsearch(a,n,mid+1,hi); // add return
} 

P.S.: 根据您在 main() 主体中的用法,您实际上只需要返回 0/1 以指示包含值与否。我会建议您使用 bool 返回类型以使其更清晰。

关于c - 我的二进制搜索实现有什么问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21709124/

相关文章:

c - 测试功能时出现未知解析错误

c - 网络接收计时器到毫秒分辨率

c - 内置函数malloc中的不兼容声明和c中赋值错误中的不兼容类型

c++ - binary_search 总是返回真 C++

python - 两个表之间的非标准交互以避免非常大的合并

java - Collections.binarySearch (Java) 中的下划线(_) 问题

c - 以字(16位)为基本变量计算CRC

c - TCP:客户端连接,发送数据并在接受之前断开连接时会发生什么

c# - 按 ID 的 BinarySearch 对象数组

java - 二进制搜索无法正常运行