2 releases
0.9.1 | Sep 19, 2020 |
---|---|
0.9.0 | Sep 19, 2020 |
#5 in #trie-node
16KB
321 lines
alias_trie
A trie that supports nodes with aliases. It can easily and quickly deal with grammatical ambiguities caused by abbreviations, abbreviations or abbreviations in daily grammar, and provide correct and fast retrieval capabilities.
lib.rs
:
alias_trie
is a trie that supports nodes with aliases. One or more aliases can be set for each node so that the stored value can be retrieved through the alias. Unfortunately, the aliases in the search path may conflict, making it impossible to locate a specific node. This situation is called grammatical ambiguity, and the search cannot be completed using ambiguity grammar.
alias_trie
can easily and quickly deal with grammatical ambiguities caused by abbreviations, abbreviations or abbreviations in daily grammar, and provide correct and fast retrieval capabilities.
ROOT
↙ ↘
A(a): 1 G: 5
↙ ↓ ↘ // The alias "f" conflicts.
B C: 4 D(d,dd): 2 // The path "A->d->f" is an ambiguous grammar.
↓ ↙ ↘
E(eee): 2 F1(f): 3 F2(f,f2): 4
Usage
This crate is on crates.io and can be
used by adding alias_trie
to your dependencies in your project's Cargo.toml
.
[dependencies]
alias_trie = "0.9"
Examples
use alias_trie::Trie;
use alias_trie::UniqueOption;
let mut trie = Trie::new();
trie.insert(&["A"], 1);
trie.insert(&["A", "B", "E"], 2);
trie.insert(&["A", "C"], 4);
trie.insert(&["A", "D"], 2);
trie.insert(&["A", "D", "F1"], 3);
trie.insert(&["A", "D", "F2"], 4);
trie.insert(&["G"], 5);
trie.update_aliases(&["A", "B", "E"], &[&["a"], &[], &["eee"]]);
trie.update_aliases(&["A", "D", "F1"], &[&[], &["d", "dd"], &["f"]]);
trie.update_aliases(&["A", "D", "F2"], &[&[], &[], &["f", "f2"]]);
assert_eq!(trie.get(&["a", "d", "F1"]), UniqueOption::Some(&3));
assert_eq!(trie.get(&["a", "d", "f2"]), UniqueOption::Some(&4));
assert_eq!(trie.get(&["a", "d", "f"]), UniqueOption::NonUnique);
assert_eq!(trie.get(&["a", "d", "g"]), UniqueOption::None);
!
Dependencies
~2–3MB
~54K SLoC