| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 855 人关注过本帖
标题:二分查找的acm题,提交了好几遍都不对,求各路大神的帮忙找找错
只看楼主 加入收藏
非若是也
Rank: 2
等 级:论坛游民
帖 子:13
专家分:21
注 册:2013-11-24
收藏
得分:0 
回复 10楼 pangshch
thank you不过……额……上边的程序好像还是有点小问题诶,好像是continue那里,,,这个。。。你程序是判断到那个点之后就输入yes,然后继续执行了。。。
而且不管之前是否知道这个数据你都最后输出“no”了。。。
大侠再帮我看看呗……
2013-11-25 22:25
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:2 
为什么不先找到自己代码的问题?


[fly]存在即是合理[/fly]
2013-11-25 22:52
pangshch
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
威 望:2
帖 子:443
专家分:1966
注 册:2013-4-9
收藏
得分:2 
回复 11楼 非若是也
sorry!
把查找那里改一下
程序代码:
while (left <= right) {               // 加个等于, 因为有等于的情况
              mid = (left + right)/2;
              if (s[mid] == x) {
              printf("YES\n");
              break;                  // 用break结束循环
              }
             else if (s[mid] < x)
                left = mid + 1;
             else
                right = mid - 1;
         }
         if (left > right)           // 加一个判断, 当left大于right时, 说明数不存在数组里面.
             printf("NO\n");
    }

2013-11-26 08:58
非若是也
Rank: 2
等 级:论坛游民
帖 子:13
专家分:21
注 册:2013-11-24
收藏
得分:0 
回复 13楼 pangshch
谢谢你提交成功啦
大神真棒!!!!!
看来我的C语言得好好复习了,再这样下去就挂科了
2013-11-26 17:40
非若是也
Rank: 2
等 级:论坛游民
帖 子:13
专家分:21
注 册:2013-11-24
收藏
得分:0 
回复 12楼 azzbcc
我C语言学的确实不好,请大神指教
2013-11-26 17:45
快速回复:二分查找的acm题,提交了好几遍都不对,求各路大神的帮忙找找错
数据加载中...
 
   



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

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