c++ - 二进制搜索的问题

标签 c++ binary-search

那里。我正在尝试对文本文件进行二进制搜索。我正在比较文本文件一和文本文件二。但是,我的二进制算法似乎无法工作并打印出它找到的元素。我的文本文件 2 是一个排序列表,我的文本文件 1 是关键。 我需要一些关于如何解决这个问题的指导。这是我的代码:

bool binary_search(const vector<string>& sorted_vec, const vector<string>& key) {
    size_t mid, left = 0;
    size_t right = sorted_vec.size(); // one position passed the right end

    while (left < right) {
        mid = left + (right - left)/2;
        for(int i=0;i<sorted_vec.size();i++){
            if (key[i] > sorted_vec[mid]){ //
                left = mid+1;
            }else if (key[i] < sorted_vec[mid]){
                right = mid;
            }else{
                return true;
            }
        }

        return false;
    }
}

最佳答案

搜索键在 binary_search 实现中 for 循环的每次迭代中都会发生变化。修改您的实现以采用单个键,并为您的键 vector 围绕它包装一个 for 循环。但是我同意@H2CO3,你应该使用std::binary_search:

#include <vector>
#include <iostream>
#include <algorithm>

using namespace std;
vector<int> sorted_vec = {1, 2, 3, 4, 5, 6, 7, 8};
vector<int> keys = {3, 5, 19, 27, 0, 2};

int main() {
    for(const auto &key : keys) {
        cout << binary_search(sorted_vec.cbegin(), sorted_vec.cend(), key) << endl;   
    }
}

输出

1
1
0
0
0
1

如果您希望使用自己的 binary_search,则需要修复当前的实现。

关于c++ - 二进制搜索的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18814696/

相关文章:

c++ - 如何在 C++ 11 中将 const 添加到元组的 get<>(t) 函数中?

c++ - 在一个范围内生成无偏随机整数的最佳算法是什么?

c++ - C++二分查找中的比较仿函数

python - Python中的二分搜索(二分法)

c - 使用 C 中的二分查找函数在数组中查找单词?

c++ - 不从派生类调用基类构造函数

c++ - 模板函数中 std::string 的类型推断失败

c++ - 将结构放入匿名命名空间有什么作用?

java - 在 Java 中查找 ArrayList 中满足条件列表的所有对象

algorithm - 实现二分搜索有哪些陷阱?