鱼C论坛

 找回密码
 立即注册
查看: 2212|回复: 9

[已解决]程序运行输入数字回车没有结果为什么

[复制链接]
发表于 2018-5-7 18:03:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
如图
最佳答案
2018-5-7 20:02:55
                else if (n < a[mid]){
                        high = mid -1;
                }
                else
                        low=mid+1;
else那里不用改,用你原来那个就好了

二分法排序程式和exe运行界面,输入数字4后回车没有结果显示,请问是为什么

二分法排序程式和exe运行界面,输入数字4后回车没有结果显示,请问是为什么
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-5-7 18:18:39 From FishC Mobile | 显示全部楼层
while循环中没有更新high的值
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2018-5-7 18:50:51 | 显示全部楼层
BngThea 发表于 2018-5-7 18:18
while循环中没有更新high的值

额,我刚更新了一下还是这样
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-7 18:51:23 | 显示全部楼层
本帖最后由 BFSDT 于 2018-5-7 19:18 编辑
else if (n < a[mid]){
    high = mid -1;
}

之前那个有误,这个应该可以
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-7 19:15:41 | 显示全部楼层

我刚看到您的回复可高兴了,可是为啥还是那个样子
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-7 19:25:41 | 显示全部楼层
爱学习的猫 发表于 2018-5-7 19:15
我刚看到您的回复可高兴了,可是为啥还是那个样子

之前那个写错了,现在修改过的应该能用了,修改相应的地方就可以了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-7 19:38:02 | 显示全部楼层
BFSDT 发表于 2018-5-7 19:25
之前那个写错了,现在修改过的应该能用了,修改相应的地方就可以了

十分抱歉,您再看一下呗,我运行了还是那个样子
int main(){
        static int a[10]={-12,0,6,16,23,56,80,100,110,115};//static是静态变量
        int n,low,mid,high,found;//一个分号算一行
        low=0;
        high=M-1;
        found=0;
        printf("Input a number to be searched:\n");
        scanf("%d",&n);

        while(low<=high){
                mid=(low+high)/2;
                if(n==a[mid]){
                        found=1;
                        break;
                }
                else if (n < a[mid]){
                        high = mid -1;
                }
                else
                        high=mid+1;
        }
        if(found==1){
                printf("The index of %d is%d",n,mid);
        }else
                printf("There is not %d",n);
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-7 20:02:55 | 显示全部楼层    本楼为最佳答案   
                else if (n < a[mid]){
                        high = mid -1;
                }
                else
                        low=mid+1;
else那里不用改,用你原来那个就好了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-5-7 20:44:42 | 显示全部楼层
楼上正解,但那句 else if ( n < a [mid]) 换成 else if ( n < mid )
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-5-8 10:48:07 | 显示全部楼层
BngThea 发表于 2018-5-7 18:18
while循环中没有更新high的值

谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-29 20:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表