首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >提供自动补全的有效搜索算法是什么?

提供自动补全的有效搜索算法是什么?
EN

Stack Overflow用户
提问于 2010-02-25 14:12:10
回答 5查看 5.2K关注 0票数 4

我有一个包含10000个关键词的列表。什么是有效的搜索算法来提供该列表的自动完成?

EN

回答 5

Stack Overflow用户

发布于 2010-02-25 16:42:28

使用Trie是一种选择,但它们的空间效率很低。通过使用称为Radix Tree或Patricia Tree的修改版本,可以使它们具有更高的空间效率。

三元搜索树可能是更好的选择。这里有一篇关于这个主题的文章:"Efficient auto-complete with a ternary search tree.“另一篇关于使用三元搜索树进行拼写更正(与自动补全类似的问题)的优秀文章是"Using Ternary DAGs for spelling correction.

票数 6
EN

Stack Overflow用户

发布于 2010-02-25 14:43:05

我认为binary search在处理10000个条目时工作得很好。

票数 4
EN

Stack Overflow用户

发布于 2010-02-25 15:50:41

一个trie:只要你输入一个字母,http://en.wikipedia.org/wiki/Trie就会给你O(N)的搜索时间(我假设你每次输入一个字母都想要新的建议)。如果你有很小的单词,这应该是相当有效的,并且每个新字母的搜索空间都会减少。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2332028

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档