| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1244 人关注过本帖
标题:小白关于二分查找的问题
只看楼主 加入收藏
yasmin
Rank: 1
等 级:新手上路
帖 子:22
专家分:4
注 册:2016-7-22
结帖率:33.33%
收藏
已结贴  问题点数:20 回复次数:9 
小白关于二分查找的问题
程序代码:
int half(int *a, int i, int j, int key)
{
    static int k = 1;
    int half ;
    if (i < j)
{
    half = (i+j)/2;
    
    if (key == a[half])
    {
        return k;
    }
    if (key > a[half])
    {
        k++;
        half(a,half+1,j,key);
    }
    if (key < a[half])
    {
        k++;
        half(a,i,half-1,key);
    }
}
return k;
}


因为要返回查找的次数 所以我返回了k,但是在编译的时候显示不用调用循环里面的函数,求大神指教啊

[此贴子已经被作者于2016-8-9 15:37编辑过]

2016-08-09 15:35
yasmin
Rank: 1
等 级:新手上路
帖 子:22
专家分:4
注 册:2016-7-22
收藏
得分:0 
求大神帮忙啊!!
2016-08-09 16:05
grmmylbs
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:54
帖 子:1409
专家分:5845
注 册:2016-2-14
收藏
得分:0 
函数名和变量名重了吧?
2016-08-09 16:07
yasmin
Rank: 1
等 级:新手上路
帖 子:22
专家分:4
注 册:2016-7-22
收藏
得分:0 
回复 3楼 grmmylbs
。。。。。有道理,半天没发现
2016-08-09 16:16
砖家的谎言
Rank: 12Rank: 12Rank: 12
等 级:禁止访问
威 望:30
帖 子:693
专家分:3898
注 册:2013-12-6
收藏
得分:7 
初学者一定要仔细,经常犯一些低级错误,不过大家都是这样过来的,要坚持,加油

我不是砖家,要努力成为砖家。
2016-08-09 16:17
yasmin
Rank: 1
等 级:新手上路
帖 子:22
专家分:4
注 册:2016-7-22
收藏
得分:0 
回复 5楼 砖家的谎言
恩恩 谢谢大神指点!
2016-08-09 16:18
linlulu001
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:20
帖 子:944
专家分:4047
注 册:2016-4-13
收藏
得分:7 
int search(const int arr[],int low,int high,int key)
{
    int mid=low+(high-low)/2;
    int d=0;
    if(low>high)  return -1;        //没查到返回-1;
    else
    {
        if(arr[mid]==key)  return d;
        else if(arr[mid]>key)  {
            d++;
            return search(arr,low,mid-1,key);
        }
        else    {
            d++;
            return search(arr,mid+1,high,key);
        }
    }

}
你的递归写错了。
2016-08-09 16:37
yasmin
Rank: 1
等 级:新手上路
帖 子:22
专家分:4
注 册:2016-7-22
收藏
得分:0 
回复 7楼 linlulu001
if(low>high)  return -1;        //没查到返回-1;


大神说的是这个问题吗?我看到了 其他还有什么错误吗? 我还想请教你一下 后面的 return 加不加有什么区别吗
2016-08-09 17:07
linlulu001
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:20
帖 子:944
专家分:4047
注 册:2016-4-13
收藏
得分:0 
回复 8楼 yasmin
我用你的子函数写了主函数来测试,返回统计的次数都不对。
所以写了一份递归的函数给你参考。
2016-08-09 18:17
yasmin
Rank: 1
等 级:新手上路
帖 子:22
专家分:4
注 册:2016-7-22
收藏
得分:0 
回复 9楼 linlulu001
谢谢大神!
2016-08-09 19:04
快速回复:小白关于二分查找的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017769 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved