| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1109 人关注过本帖
标题:用半折法查找数字。。。帮帮看这个程序,哪里错了,为什么是死循环?
只看楼主 加入收藏
wwfdzh2012
Rank: 2
等 级:论坛游民
帖 子:88
专家分:27
注 册:2012-11-22
结帖率:94.12%
收藏
已结贴  问题点数:20 回复次数:13 
用半折法查找数字。。。帮帮看这个程序,哪里错了,为什么是死循环?
程序代码:
#include<stdio.h>
//#define N 15
void main()
{
    int a[15]={15,14,13,12,11,10,9,8,7,6,5,4,3,2,1};
        int i,flag,m,n,number,p;

        //printf("由大到小输入15个数字:");   
        //for(i=0;i<15;i++)
          // scanf("%d",&a[i]);
        printf("请输入要查找的数:");
        scanf("%d",&number);
   
        flag=0;
        if(number<=a[0]&&number>=a[14])
        {
          m=0,n=14;
             p=(m+n)/2;
                   
            while(flag==0&&p!=0)
            {
              p=(m+n)/2;
              if(number==a[0])
              {flag=1;p=0;}
              else if(number==a[14])
              {flag=1;p=14;}
              else if(number>a[p])   
                  m=0,n=p;
              else if(number<a[p])
                  m=p,n=14;
           
              if(number==a[p])flag=1;
            }
              if(number==a[p])flag=1; 

        }   
    if(flag==0)printf("查无此数!\n");
    else if(flag==1)printf("该数为第%d个数\n",p+1);
}
查找4,7,9,10,11,13会进入死循环,不知道为什么。。。

[ 本帖最后由 wwfdzh2012 于 2012-12-30 11:44 编辑 ]
搜索更多相关主题的帖子: color 
2012-12-30 11:11
wwfdzh2012
Rank: 2
等 级:论坛游民
帖 子:88
专家分:27
注 册:2012-11-22
收藏
得分:0 
帮帮忙。。。
2012-12-30 11:45
a4811
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:100
专家分:107
注 册:2012-12-20
收藏
得分:0 
哥们,你程序比较乱啊,不好理解。
2012-12-30 12:46
hongyinppp
Rank: 2
等 级:论坛游民
帖 子:3
专家分:20
注 册:2012-12-30
收藏
得分:20 
你好,把28行的m=0,30行的n=14删掉,代码如下
#include<stdio.h>
//#define N 15
void main()
{
    int a[15]={15,14,13,12,11,10,9,8,7,6,5,4,3,2,1};
        int i,flag,m,n,number,p;

        //printf("由大到小输入15个数字:");   
        //for(i=0;i<15;i++)
          // scanf("%d",&a[i]);
        //printf("请输入要查找的数:");
        scanf("%d",&number);
   
        flag=0;
        if(number<=a[0]&&number>=a[14])
        {
          m=0,n=14;
             p=(m+n)/2;
                  
            while(flag==0&&p!=0)
            {
              p=(m+n)/2;
              if(number==a[0])
              {flag=1;p=0;}
              else if(number==a[14])
              {flag=1;p=14;}
              else if(number>a[p])   
              /*m=0,*/n=p;
              else if(number<a[p])
                  m=p/*,n=14*/;
           
              if(number==a[p])flag=1;
            }
              if(number==a[p])flag=1;

        }   
    if(flag==0)printf("no!\n");
    else if(flag==1)printf("it is %d num\n",p+1);
}

2012-12-30 12:53
qunxingw
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:24
帖 子:1676
专家分:7295
注 册:2011-6-30
收藏
得分:0 
不好意思,没有细看

[ 本帖最后由 qunxingw 于 2012-12-30 13:06 编辑 ]

www.qunxingw.wang
2012-12-30 13:01
想々
Rank: 2
来 自:新邵
等 级:论坛游民
帖 子:67
专家分:40
注 册:2012-12-23
收藏
得分:0 
看得很辛苦!还是不懂!
2012-12-30 13:04
wwfdzh2012
Rank: 2
等 级:论坛游民
帖 子:88
专家分:27
注 册:2012-11-22
收藏
得分:0 
回复 4楼 hongyinppp
非常感谢,但是为什么查找4会进入死循环,那两个赋值语句的影响?能讲解一下吗?
2012-12-30 14:44
wwfdzh2012
Rank: 2
等 级:论坛游民
帖 子:88
专家分:27
注 册:2012-11-22
收藏
得分:0 
再来帮帮我。。。
2012-12-30 21:13
hongyinppp
Rank: 2
等 级:论坛游民
帖 子:3
专家分:20
注 册:2012-12-30
收藏
得分:0 
对,的确是那两个赋值语句的影响,打个比方,要查的数在位置11,第一次p=(0+14)/2=7,下界=p=7,上界=14                                                         
                                                             第二次p=(7+14)/2=10,下界=p=10,上界=14,
                                                                                下界=0,上界=12
                                                                                  下界=6,上界=14
                                                                                 下界=10,上界=14
                                                                                 下界=0,上界=12这个东西在上面出现过,所以下面就是死循环了

举个例子,第三次时只需在10~12之间找。
2012-12-31 13:01
wwfdzh2012
Rank: 2
等 级:论坛游民
帖 子:88
专家分:27
注 册:2012-11-22
收藏
得分:0 
回复 9楼 hongyinppp
非常感谢。。。
2012-12-31 18:29
快速回复:用半折法查找数字。。。帮帮看这个程序,哪里错了,为什么是死循环?
数据加载中...
 
   



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

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