在具有父 ID 的一般树中查找最低共同祖先
finding the Lowest Common Ancestor in a general tree having the parent Ids
我的诀窍是找到一个通用树的LCA,该树将从txt文件中的列表创建。我正在寻找最有效的实施。 数据的形式为:Id, info, ParentId
数据不以任何方式排序。我正在考虑创建一棵树,但这至少需要 O(nlogn)。虽然日志基数不是 2。我想这取决于平均儿童的数量。
相反,如果我将节点存储在哈希表中,那么找到LCA会比O(nlogn)更好。右?对于目标节点的每个父节点,我必须检查源节点是否访问过它(假设我们从源节点开始到根节点,并将途中的所有父节点标记为已访问),这需要 O(logn)。因为,我们只是检查父母,它会比O(nlogn)更好。
有什么更好的主意吗?
假设你的树在某种程度上是平衡的,即O(logn)高度,你的哈希表数据结构应该给出一个O(n)算法。
从源和目标到根的第一个跟踪。您将有两条长度为 O(logn) 的路径。例如SXYZR和DWYZR。S 和 D 是源和目标。R 是根。这需要 O(logn) 时间。
然后你可以找到最长的后缀,即 YZR。Y 将是 LCA。这需要 O(logn) 时间。
请记住,您需要 O(n) 时间来读取输入并构建哈希表。
相关文章:
- 正在查找文档以获得PS4平台的C++中的设备信息
- 在C++中查找文件
- 模板元程序查找相似的连续类型名称
- 在UNIX系统中使用DIR查找文件的字节大小
- 查找最接近的大于当前数字的数字的索引
- 有没有一种方法可以创建一个带有哈希表的数据库,该哈希表具有恒定时间查找功能
- 查找后更改类变量
- 使用正则表达式regex_search在字符串中查找字符串
- 使用gcc从静态链接的文件中查找可选符号
- 在C++中查找范围的长度
- 算法问题:查找从堆栈中弹出的所有序列
- 在Windows中查找扬声器输出的当前音量级别
- 如何在C++中使用X509证书模在令牌中查找私钥
- 使用.find函数在c++中查找字符和另一个字符之间的大小
- 在 Windows 上,是否可以让 dll 在不使用 PATH 环境变量的情况下在另一个文件夹中查找依赖项?
- 在 for 循环中查找问题时遇到困难
- 用于查找最低共同祖先的代码不适用于某些测试用例
- 在 n 元树 c++ 中查找给定节点的祖先
- 查找树中两个节点的最小共同祖先
- 在具有父 ID 的一般树中查找最低共同祖先