概括
所以我有一个有向无环加权图,其中每条边都有一个输入和输出节点,每个节点都有一个 ID,我使用字典将所有传入边按其 ID 映射到一个节点,另一个对所有传出边执行相同操作所以当呈现节点 ID 时,我可以在 ~O(1) 时间内告诉所有传入和传出边。
要求
我需要能够添加新的随机边(即连接两个随机节点),以保证无论图形有多大,它都不会有任何循环。
我试过的
由于我完全控制了如何构建我的图,我可以对其进行拓扑排序并使用卡恩算法来确定对于两个均匀随机选择的节点 N1 和 N2,该图是否会在 O(n) 时间内产生一个循环。问题是如果它发生了怎么办?我必须尝试一个新的随机配对并重复这个过程,直到我幸运为止。这听起来好像它与图的缩放比例真的很差,因为图的边缘越密集,一个新的随机图就越有可能创建一个循环。
我还阅读了这篇文章: 生成随机 DAG ,这在本质上与我的问题相似,但是,我不能使用建议的解决方案来根据节点的 ID 连接节点,而只能连接较小的 ID(之前的节点)由于我对这个问题有其他限制,所以节点是新的)。
问题
有没有办法设计一个结构,只允许我在节点之间随机选择,如果通过新边缘连接,任何一个都不会产生与内存开销无关的循环?这应该是一个 O(1) 操作。