我正在为 VB.NET 中的预测文本输入实现一个 trie - 就 trie 的使用而言,基本上是自动完成。我已经使我的 trie 成为基于通用字典类的递归数据结构。
基本上是:
class WordTree Inherits Dictionary(of Char, WordTree)
单词中的每个字母(全部大写)都用作新 WordTrie 的键。叶子上的空字符表示单词的终止。要找到以前缀开头的单词,我会一直走到我的前缀,然后收集所有子单词。
我的问题基本上是关于 trie 本身的实现。我正在使用字典哈希函数来分支我的树。我可以使用一个列表并对列表进行线性搜索,或者做其他事情。这里有什么流畅的动作?这是进行分支的合理方法吗?
谢谢。
更新:
只是为了澄清,我基本上是在问字典分支方法是否明显不如其他替代方法。我使用此数据结构的应用程序仅使用大写字母,因此数组方法可能是最好的。我可能会在未来更复杂的预输入情况(更多字符)中使用相同的数据结构。在这种情况下,听起来字典是正确的方法——直到我需要使用更复杂的东西。