折半查找求助

萌萌的小张飞 2021-04-07 08:34:37



请问为什么会出现个别错误呢?我的代码有什么问题吗?请各位前辈大神指教!谢谢!!
...全文
201 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
qzjhjxj 2021-04-08
  • 打赏
  • 举报
回复
供参考:
#include<iostream.h>
using namespace std;

int seek(int *p,int high,int mu){
     int low=0;
     int mid;
     while(low<=high){
           mid = (low+high)/2;
           if(p[mid]==mu){//查找到
              return mid+1;
           }else if(p[mid]<mu){
              high = mid-1;
           }else{
              low = mid+1;
           }
     }
     return 0;
}


int main(void)
{
    int n,i,t,m;
    cin>>n;
    int *a = new int[n];
    for(i=0;i<n;i++)
        cin>>a[i];
    cin>>t;
    while(t--){
          cin>>m;
          cout<<seek(a,n-1,m)<<endl;
    }
    delete []a;
    
    return 0;
}
lin5161678 2021-04-08
  • 打赏
  • 举报
回复
引用 3 楼 智者知已应修善业 的回复:
由图可知查找次数,找到10用3次,其余类推。
又在误导人 你的查找函数 都不用考虑查找失败的情况吗 只要key 没有在数组里面 你的代码就有可能出现数组越界? 这就很离谱知道吗
NorZ 2021-04-07
  • 打赏
  • 举报
回复
我猜是和元素个数是奇数还是偶数相关吧

65,187

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧