繁体   English   中英

为什么此代码不产生输出? 使用xcode的C ++二进制搜索

[英]Why this code does not produce output? c++ binary search using xcode

//使用c ++进行二进制搜索。 main函数不提供任何输出。 这是简单的二进制搜索算法实现。

#include <iostream>
using namespace std;
int BinarySearch(int *a, int x, int n ){
    int left = 0;
    int right = n-1;
    while(left<=right){
        int middle = left + right /2;
        if (x>a[middle]) {
            left = middle +1;
        }
        else if (x<a[middle]){
            right = middle -1;
        }
        else return middle;
    }
    return 1;
}

int main(int argc, const char * argv[])
{
    cout<<"Hello World";
    int a[] ={1,2,3,4,5,6,7,8,9,10};
    int x = 3;
    int n = 10;
    int var = BinarySearch(a, x, n);
    cout<<"The search result:"<<endl;
    cout<< var;
    return 0;

}

您缺少周围的偏瘫

int middle = left + right / 2;

一定是

int middle = (left + right) / 2;

而且您可能还想返回

return a[middle];    //instead of middle;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM