当前位置:  开发笔记 > 运维 > 正文

如何在多级引用和依赖项中检测循环逻辑或递归

如何解决《如何在多级引用和依赖项中检测循环逻辑或递归》经验,为你挑选了1个好方法。

我有一个像这样的多级依赖图,我需要在这个图中检测任何循环引用.

A = B.

B = C.

C = [D,B]

D = [C,A]

有人有这样的问题吗?

有什么办法吗

谢谢,对不起英语.

=========更新==========

我有另一种情况.

1

2 = 1

3 = 2

4 = [2,3]

5 = 4

在这种情况下,我的递归代码在"4"引用中迭代两次,但是这个引用不会生成无限循环.我的问题是知道函数何时迭代多次引用并且不是无限循环,何时是无限循环,以通知用户.

1 = 4

2 = 1

3 = 2

4 = [2,3]

5 = 4

这种情况与第二个例子有点不同.这会产生无限循环.我怎么知道案件何时产生无限循环?



1> RossFabrican..:

拓扑排序.维基百科上的描述很清楚,适用于您的所有示例.

基本上,您从一个没有依赖项的节点开始,将它放在已排序节点的列表中,然后从每个节点中删除该依赖项.对于你的第二个例子,这意味着你从1开始.一旦你删除所有依赖关系1你剩下2.你最终排序他们1,2,3,4,5并看到没有周期.

对于您的第三个示例,每个节点都有一个依赖项,因此无处可寻.这样的图必须包含至少一个循环.

推荐阅读
牛尾巴2010
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有