[发明专利]一种基于迭代的图搜索方法有效
申请号: | 201811220912.4 | 申请日: | 2018-10-19 |
公开(公告)号: | CN109299337B | 公开(公告)日: | 2022-05-13 |
发明(设计)人: | 陈光淙;张少伟;蔡世涌 | 申请(专利权)人: | 南威软件股份有限公司 |
主分类号: | G06F16/901 | 分类号: | G06F16/901;G06F16/903 |
代理公司: | 泉州市潭思专利代理事务所(普通合伙) 35221 | 代理人: | 廖仲禧 |
地址: | 362000 福建省*** | 国省代码: | 福建;35 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 搜索 方法 | ||
本发明公开了一种基于迭代的图搜索方法,提高图搜索的效率。该方法包括:将图数据库中的第一节点加入到队列中,图数据库中包括网络图中的N个节点;以第一节点作为父节点遍历图数据库,从图数据库中搜索出第二节点,第一节点与第二节点之间存在连边,且第二节点是没有被标记为已处理的节点;将第二节点加入到队列中,并将第一节点标记为已处理的节点;将第一节点从队列中弹出,判断队列中的所有节点是否被弹出,若还存在没有被弹出的节点,将队列中还剩余的节点作为父节点重新搜索图数据库,并搜索到新的节点之后更新队列,直至队列中的所有节都被弹出,结束图搜索流程。
技术领域
本发明涉及计算机技术领域,具体涉及一种基于迭代的图搜索方法。
背景技术
在关系网络的应用场景中,通常需要对某个节点的关系链进行分析,尤其在大数据的应用中。
现有技术中提供的图搜索方法主要基于递归实现,即通过函调用自身的算法,并在该算法执行过程中需要采用递归的方式多次判断退出的条件,当该条件满足时,即遍历完成,算法退出。
由于现有技术基于递归实现图搜索,而递归是重复调用函数自身实现的循环,因此常常造成方法的栈溢出。即函数调用是通过栈实现的,递归方式调用图搜索需要递归调用自身方法,相当于持续的调用方法,而且不能释放栈,当调用深度足够深时,栈空间不足就会造成栈溢出。
发明内容
本发明的目的在于提供一种基于迭代的图搜索方法,用于提高图搜索的效率。
为了达到上述目的,本发明采用这样的如下技术方案:
本发明提供一种基于迭代的图搜索方法,包括:
将图数据库中的第一节点加入到队列中,所述图数据库中包括网络图中的N个节点,其中,所述第一节点属于所述N个节点中的一个节点,所述N个节点中存在通过连边相连接的至少两个节点,所述N为正整数;
以所述第一节点作为父节点遍历所述图数据库,从所述图数据库中搜索出第二节点,其中,所述第二节点属于所述N个节点中的一个节点,所述第一节点与所述第二节点之间存在连边,且所述第二节点是没有被标记为已处理的节点;
将所述第二节点加入到所述队列中,并将所述第一节点标记为已处理的节点;
将所述第一节点从所述队列中弹出,判断所述队列中的所有节点是否被弹出,若还存在没有被弹出的节点,将所述队列中还剩余的节点作为父节点重新搜索所述图数据库,并搜索到新的节点之后更新所述队列,直至所述队列中的所有节都被弹出,结束图搜索流程。
采用上述技术方案后,本发明提供的技术方案将有如下优点:
在本发明实施例中,首先将图数据库中的第一节点加入到队列中,然后以第一节点作为父节点遍历图数据库,在第一节点与第二节点之间存在连边,且第二节点是没有被标记为已处理的节点的情况下,该第二节点作为从图数据库中搜索出的节点,接下来将第二节点加入到队列中,并将第一节点标记为已处理的节点,最后将第一节点从队列中弹出,判断队列中的所有节点是否被弹出,若还存在没有被弹出的节点,将队列中还剩余的节点作为父节点重新搜索图数据库,并搜索到新的节点之后更新队列,直至队列中的所有节都被弹出,结束图搜索流程。本发明实施例中使用队列来管理图数据库中的节点,并对该队列中的节点进行插入和弹出的管理控制,从而通过以父节点的身份遍历图数据库的方式,使得图数据库中存在父子关系的节点都被插入到队列中,本发明实施例中还采用标记已处理节点的方式减少了遍历的复杂度,本发明实施例提供一种由近至远的图搜索方式,通过迭代以及队列的图搜索方式代替现有技术的递归遍历方法,因此提高图搜索的效率,且克服了现有技术的栈溢出的风险。
附图说明
图1为本发明实施例提供一种基于迭代的图搜索方法的流程方框示意图;
图2为本发明实施例提供的基于迭代的图搜索方法的一种应用场景示意图;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于南威软件股份有限公司,未经南威软件股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811220912.4/2.html,转载请声明来源钻瓜专利网。