为什么Google不提供部分搜索?是因为指数太大了吗?

29 search substring

谷歌/ Gmail的/等.不提供部分或前缀搜索(例如东西*)虽然它可能非常有用.我常常在GMail中找不到邮件,因为我不记得确切的表达方式.

我知道有干事等等,但它不一样,特别是如果我们谈论的是英语以外的语言.

为什么Google不添加这样的功能?是因为索引会爆炸吗?但数据库提供部分搜索,所以肯定有很好的算法来解决这个问题.

这里有什么问题?

Rui*_*ira 8

Google会搜索部分字词.但Gmail不是.既然你问这里有什么问题,我的答案就是缺乏努力.这个问题有一个解决方案,可以在恒定的时间和线性空间搜索,但不是非常缓存友好:后缀树.后缀阵列是另一种选择,它更加缓存,并且仍然具有时间效率.


Byr*_*ock 7

Google实际上并不存储其搜索的文本.它存储搜索术语,页面链接以及术语存在的页面位置.该数据结构以传统数据库意义索引.我敢打赌,使用通配符会使索引的索引相当缓慢,正如Developer Art所说,这不是很有用.

  • 我找到了一个可以做前缀(东西*)和邻近搜索的搜索引擎![Exalead Web Search](http://www.exalead.com/search/).单击"高级搜索"以查找这些选项. (3认同)
  • @HughBrackett感谢您的提示,但恐怕Exalead同时已经从其选项中删除了前缀搜索,即使在高级搜索中也是如此。:-(无处可寻。 (2认同)

pba*_*ski 5

可以通过Google文档 - 按照这篇文章:

http://www.labnol.org/internet/advanced-gmail-search/21623/