Header-only Burkhard-Keller tree implementation in C++, with different metrics and a few useful interfaces supported. Documentation can be found here.
#include "bktree.hpp"
#include <iostream>
int main() {
using metric_t = bk_tree::metrics::DamerauLevenshteinDistance;
using tree_t = bk_tree::BKTree<metric_t>;
// 🌟 Initializer list syntax
tree_t temp{"tall", "tell", "teel"};
temp.insert("feel");
tree_t tree(temp);
// 🌟 Loop like a STL container (e.g. range-based)
for (auto const &node : tree) {
std::cout << *node << ' '; // tall tell teel feel
std::cout << node->word() << ' '; // tall tell teel feel
}
std::cout << std::endl;
std::cout << "Tree size: " << tree.size() << std::endl; // Tree size: 4
// 🌟 Find all possible results
auto result = tree.find("tale", 1);
for (auto &p : result) {
std::cout << p.first << " " << p.second << std::endl; // tall 1
}
// 🌟 Erase a node by word
tree.erase("tall");
result = tree.find("tale", 1);
std::cout << result.size() << std::endl; // 0
}
This repository is licensed under The GNU General Public License v3.0. See also LICENSE for details.
Fred J. Damerau. 1964. A technique for computer detection and correction of spelling errors. Communications of the ACM 7, 3 (1964), 171–176. DOI:http://dx.doi.org/10.1145/363958.363994
Vladimir I. Levenshtein. 1966. Binary codes capable of correcting deletions, insertions, and reversals. Soviet physics doklady 10, 8 (1966), 845-848.
W.A. Burkhard and R.M. Keller. 1973. Some approaches to best-match file searching. Communications of the ACM 16, 4 (1973), 230–236. DOI:http://dx.doi.org/10.1145/362003.362025