首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >递归二分查找程序

递归二分查找程序
EN

Stack Overflow用户
提问于 2013-11-10 07:30:57
回答 1查看 103关注 0票数 0

下面是我的递归二进制搜索方法。这是为了从一个排序的列表中找到一个电话号码,但它只对文件中的第一个号码有效,并显示所有其他号码都找不到。有人能帮我找出哪里出了问题吗?

代码语言:javascript
复制
static int binary (String num, String[] phone, int low, int high)
{
    if ((high - low) <= 1)
    {
        if (phone [low].equals (num))
        {
            return low;
        }
        else if (phone [high].equals (num))
        {
            return high;
        }
        else
        {
            return -1;
        }
    }
    int mid = (low + high) / 2;
    if (phone [mid].compareTo (num) > 0)
    {
        return binary (num, phone, 0, mid);
    }
    else if (phone [mid].compareTo (num) < 0)
    {
        return binary (num, phone, mid, high);
    }
    else
    {
        return -1;
    }
}
EN

回答 1

Stack Overflow用户

发布于 2013-11-10 07:39:48

我觉得你想

代码语言:javascript
复制
if (phone [mid].compareTo (num) > 0)
{
    return binary (num, phone, low, mid-1);
}
else if (phone [mid].compareTo (num) < 0)
{
    return binary (num, phone, mid+1, high);
}

此外,您需要执行比必要的检查更多的检查:

代码语言:javascript
复制
static int binary (String num, String[] phone, int low, int high)
{
    if(low > high)
    {
        return -1;
    }
    int mid = (low + high) / 2;
    int compare = phone[mid].compareTo(num);
    return compare > 0 ? binary (num, phone, low, mid-1);
        : compare < 0 ? binary (num, phone, mid+1, high);
        -1;
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19884468

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档