These predicates implement “association list” primitives. They use
a binary tree representation. Thus the time complexity for these
predicates is O(lg N), where N is the number of keys.
These predicates also illustrate the use of compare/3
for case
analysis.
The goal get_assoc(
Key,
Assoc,
Value)
is
true when Key is identical to one of the keys in Assoc, and
Value unifies with the associated value.
get_assoc(Key, t(K,V,L,R), Val) :- compare(Rel, Key, K), get_assoc(Rel, Key, V, L, R, Val). get_assoc(=, _, Val, _, _, Val). get_assoc(<, Key, _, Tree, _, Val) :- get_assoc(Key, Tree, Val). get_assoc(>, Key, _, _, Tree, Val) :- get_assoc(Key, Tree, Val).