string - 找到每个词的频率

标签 string algorithm graph dictionary string-search

面试中有一个问题问我,但我无法回答。

问题是:

给定一个有向图,其中每个节点都是一个字符,同时给定一个字符串数组。 任务是通过在图中搜索来计算数组中每个字符串的频率。

我的做法:用了trie,Suffix tree,面试官不是很满意。你能给我一个给定问题的算法吗?

最佳答案

下面如何...求一个字符串 s 在有向图中出现的次数。

  • 从面包优先搜索开始(标记已经访问过的节点以避免循环)
  • 当找到第一个字符时,切换到深度优先搜索,max-depth = length(s)
  • 如果检测到字符串序列,则为 DFS 的每次出现增加出现次数
  • 恢复 BFS

注意事项

  • 我不认为 DFS 应该共享 BFS 的已访问节点列表(例如,您可能需要回到开头并重叠
  • BFS 也不应该共享 DFS 访问列表。例如,您可能正在寻找“Alan”并找到“AAlan”,并确保在第二个 A 上重新开始

现在对于一个数组,我可以为每个字符串重复这个过程。当然可能有更有效的解决方案,但我会以这种方式开始考虑。

您的回答是否包含有关广度优先或深度优先搜索的任何对话?如果有人提到要搜索图表,我几乎总是会用其中一个的变体来回复

关于string - 找到每个词的频率,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12973622/

相关文章:

c++ - 掷硬币游戏 : Optimization problem

java - 装箱/拆箱多维原始数组的最有效方法

c++ - 像 std::vector 中的元素一样就地合并

c++ - 查找给定根中的所有生成树

python - 显示每个条形图的均值虚线

string - 在 R 中使用字符串名称分配 data.frame 的列

Android:JSON 字符串数据与其他字符串比较

javascript - 将时间字符串转换为更清晰的格式

php - 用php替换大文件中的字符串

algorithm - 检查一个简单的无向图是否是三连通的