找不到二进制搜索代码错误
Binary Search Code error can not be find
下面的代码无法得到正确的答案,但我不知道哪一部分错了。它的逻辑看起来是正确的,它无法运行出正确的答案
/*binary search*/
int binary_search(const vector<int> &a,int x) {
long left = 0;
int mid;
long right=a.size()-1;
//write your code here
while (a[left]<a[right]){
mid=a[left+(right-left)/2];
if (a[mid]==x){
return mid;
}
else if (a[mid]>x){
right=mid-1;
}
else{
left=mid+1;
}
}
return -1;
}
您的循环应该由left <= right
进行调节。此外,mid
应为mid = (left + right)/2;
相关文章:
- 错误处理.将系统错误代码映射到泛型
- 为什么我在使用void函数时得到错误代码C2276
- 尝试链接我的着色器时,我收到错误代码"error c5145 must write to gl_position"
- 逻辑运算符上出现错误代码 a')'
- 'val' Arduino 错误代码之前的预期'('
- 我在贪吃蛇游戏中收到了错误代码 -1073741571
- 根据 GetLastError 直接写入磁盘会导致错误代码 5
- 当我选择大于 720 的矩阵大小时,程序退出并显示错误代码.可能是什么原因?
- 创建进程 API 失败,在窗口 122 上出现错误代码 10
- 使用另一个函数调用一个函数(都在类中)时出现问题.没有错误代码C++
- 当命令失败时,gzip 会在 C++ 中返回错误代码吗?
- 从 C++ 调用 cURL 命令会返回意外的错误代码,如 1792 和 6656
- WSALookupServiceBegin() 上的错误代码 10022(无效的 arugment)
- C++ Schannel POST 400 错误代码错误请求
- openCL-创建子缓冲区返回错误代码13
- 更新了Runge-Kutta(RK4)C++错误代码中的二阶DE
- 获取有关使用未初始化内存的错误代码
- 排序程序的意外错误代码
- 正在将DJI错误代码记录到流中
- 来自API的错误代码..处理什么是好的做法