树状数据怎么找出循环

kingstarer 2012-09-24 10:47:09
现在手上有一组描述一个树状结构的数据,形式如下:


节点 父节点(0代表根)
1 0
2 1
3 1
4 2
5 3
6 2
7 5
8 6
======================
现在这组数据里面有一两个出现问题,导致出现循环,想要找出这些数据,不知道怎么处理?

例如,节点7的父节点错写成7,导致自身出现7->7死循环
或者节点2的父节点错写成8,这样会出现2->8->6->2的死循环

怎么找出这些出了错的节点呢? (上面例子中的7和2)
...全文
200 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
kingstarer 2014-04-01
  • 打赏
  • 举报
回复
无满意结贴了 感谢各位回复
kingstarer 2012-09-27
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 的回复:]

深度遍历整棵树,每个节点都设一个标志位,初始为假,第一次访问时设为真
正常的深度遍历每个节点只访问一次(退回上一个节点不视为访问)
当访问到某个节点发现它的标志位已经为真时,就可以确定有环存在
[/Quote]

用这个方法不大可行啊 例如节点2的父节点错写成8,这样会出现2->8->6->2的死循环

这个循环是独立于树型的

不过可以改改,初始化标志位为0,访问一次将标志位加1,最后算标志位有没有不是1的

谢谢了
baichi4141 2012-09-25
  • 打赏
  • 举报
回复
深度遍历整棵树,每个节点都设一个标志位,初始为假,第一次访问时设为真
正常的深度遍历每个节点只访问一次(退回上一个节点不视为访问)
当访问到某个节点发现它的标志位已经为真时,就可以确定有环存在
vssvss 2012-09-25
  • 打赏
  • 举报
回复
给你个思路 看样子 可以当成有向图来看 先建立一个有向图 然后判断这个图是否存在环 可以用狄克斯特拉算法 来求解。至于怎么创建图 可以用链表方式来做比较方便点
kingstarer 2012-09-25
  • 打赏
  • 举报
回复
没人关注,顶一下
冷月清晖 2012-09-24
  • 打赏
  • 举报
回复
贴代码吧。
kingstarer 2012-09-24
  • 打赏
  • 举报
回复
没代码啊 是上来请教各位的

64,640

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧