| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1422 人关注过本帖
标题:折半查找法,最后一个数找不到
取消只看楼主 加入收藏
凌彬严
Rank: 1
等 级:新手上路
帖 子:38
专家分:1
注 册:2009-7-13
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:1 
折半查找法,最后一个数找不到
以下代码找不到最后一个数100001,错在哪里?帮找下原因.
/*100000个数从小到大排列,输入任意数找出其所在位置,无则输出“无此数”,用折半查找法*/
#include <stdio.h>
main()
{
    int a[100000];
    int i,b,sta,mid,end;
    for(i=0;i<100000;i++)
    {    
        a[i]=i+1;
    }
    a[99999]=100001;
    printf("%d\n",a[99999]);
line1:
    sta=1,mid=100000/2,end=100000;
    printf("b=\n");
    scanf("%d",&b);
    for(i=1;i<=100000;i++)
    {
       if(b<a[mid-1])
       {
          end=mid;
          mid=sta+(end-sta)/2;
       }
       else if(b>a[mid-1])
       {
          sta=mid;
          mid=sta+(end-sta)/2 ;
       }
       else
       {
           printf("在第%d位\n",mid);
           mid=-1;
           break;
       }         
    }
    if(mid!=-1) printf("查无此数\n");
    if(getch()!=13) goto line1;
}
搜索更多相关主题的帖子: 出错 折半查找 
2009-08-15 23:32
凌彬严
Rank: 1
等 级:新手上路
帖 子:38
专家分:1
注 册:2009-7-13
收藏
得分:0 
我昨晚找到了原因,我的算法必须将数列个数视为N+1个,即初始end=n+1,这样就能保证查找最后一位数.
2009-08-16 08:15
快速回复:折半查找法,最后一个数找不到
数据加载中...
 
   



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

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