- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 Py2neo,但这可能并不重要,因为这很可能需要通过编写 Cypher 查询来完成。
本质上,我想在子图中找到一条最短路径,其中子图占整个图的大部分,但删除了很小一部分(百万分之一或更少)的边。
例如,假设我有节点 A、B 和 C,以及边 (A->B)、(A->C)、(B->C)。当然,从 A 到 C 的最短路径是通过直接连接。但是,如果我想找到不使用该边的最短路径,则必须是 A B C。
此外,这将是用户可以在多用户(网络)应用程序中指定的内容。所以我不能真正改变数据库本身......如果这不是问题,我也许可以在边上创建一个属性“允许:真/假”并将其设置为假,但这会扰乱应用程序的行为所有当前用户。
对此的一种变体是“不允许:sessionID1、sessionID230、sessionID1010”,即实际存储哪些应用程序 session 想要在边缘本身中排除该边缘,但这似乎也不理想。
当然,我实际上可以在 python 中实现 BFS,方法是根据需要从 neo4j 获取节点并将它们保存在队列中,而不是让 neo4j 进行搜索,但肯定会慢得多,对吧?
有什么想法吗?谢谢
编辑:请求查看代码。
下面是我目前如何获得我首先在索引中查找的两个节点之间的最短路径。现在图像还有一个边列表(即唯一关系),在最短路径搜索中必须忽略这些边。
from py2neo import neo4j
g = neo4j.GraphDatabaseService()
def shortest_path(a, b):
a = g.get_indexed_node("worddex", "word", a)
b = g.get_indexed_node("worddex", "word", b)
if not a and b: return None
query_string = "START beginning=node(%d), end=node(%d) MATCH p = shortestPath(beginning-[*..100]-end) RETURN p" % (a._id, b._id)
result = neo4j.CypherQuery(g, query_string).execute()
if not len(result): return None
p = result[0].p
ret = []
for node in p.nodes:
ret.append(node["word"])
return ret
编辑 2:示例控制台:http://console.neo4j.org/r/3c1rgn
在任意两个人之间找到一条最短的“友谊路径”很容易,但是如果我们想找到一条不涉及特定友谊关系(或特定的一组关系)的最短友谊路径怎么办? friendship rels),但不先修改数据库?例如,我们想要找到从 bob 到 joe 的最短友谊路径,其中我们暂时假设 bob 和 joe 本身不是 friend ,alice 和 janet 也不是。
最佳答案
你不能使用'allShortestPaths吗? ' 密码中的选项并使用它来拒绝包含某些特定 rel 类型或使用 python 的节点类型的路径?我想这将取决于您想要限制结果的方式和参数,以及是否可以仅使用以路径形式返回给 python 的密码来检测它们。
另一种方法是指示 Cypher 将所有可能的路径从一个节点返回到另一个节点(可以在此处的查询本身中应用一些智能限制)。
然后根据 Cypher 返回的路径集合,您可以运行一些 Python 代码来拒绝包含您不感兴趣的特定 rel 类型或节点类型的路径。然后您将得到一个集合符合您的接受标准的可能路径(最短条件除外)。然后,您可以使用 python 简单地计算路径的长度,并使用最小的。
其实对于所有的路径,Cypher自己都可以返回路径的长度。这已经被问过,所以here is the question供你引用。这个问题的公认答案就是我所说的。
关于python - 找到排除特定边缘的最短路径?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23239167/
BufferedImage image = ImageIO.read(SpriteSheet.class.getResource(path)); BufferedImage image = Image
希望有人能够帮助我解决将我的 React 应用程序推送到 Heroku 时遇到的问题。 heroku 日志反复显示以下错误。 at=error code=H10 desc="App crashed"
我是 Kotlin 的新手,我正在经历这样的例子。 . . package com.example.lambda1 import spark.Spark.get fun main(args: Arra
如果您已经安装了 32 位 JDK,请在中定义一个 JAVA_HOME 变量 Computer>System Properties>System Setting>Enviorment VAriable
我正在开发一个独立于平台的应用程序。我收到一个文件 URL*。在 Windows 上,这些是: file:///Z:/folder%20to%20file/file.txt file://host/f
我在 OSX、Objective-C 上。 我有一个像 这样的路径/NSURL /Users/xxx/Desktop/image2.png 但我将它传递给第三方应用程序,该应用程序会像 excpect
我已经安装了 Android studio 和插件的 DART,FLUTTER 来启动 flutter,但是因为我在创建我的第一个 flutter 项目时无法提供 sdk 路径。 最佳答案 我试图找出
127.0.0.1:8000/api/仅包含来自第二个应用程序的 url,但我将两个 url 模块链接到相同的模式。甚至有可能做到这一点吗? 第一个应用程序: from django.urls imp
对于大量图像(大约 1k,加上相同数量的拇指,在大约 500 个文件夹中),我们要求网站上使用的所有图像 URI 都必须具有 SEO 优化路径。它们已经准备好并提供完整的路径结构(每个文件夹包含一个具
为什么 f 不是一个文件?什么可能导致这种情况? String currentPhotoPath = "file:/storage/sdcard0/Pictures/someFileName.
Gradle 中的项目名称或路径中允许使用哪些字符? 它是否与特定操作系统的目录名称中允许的字符相同(例如: http://en.wikipedia.org/wiki/Filename#Reserve
我有一个包含文件夹路径的表格。我需要找到层次结构中这些文件夹之间的所有“差距”。我的意思是,如果表格包含这 3 个文件夹: 'A' 'A\B\C' 'A\B\C\D\E\F\G' 我需要在层次结构中找
我在 Linux 服务器上的/home/subversion 中安装了 svn - 那里有一个 ROOT 文件夹,其中包含 db 和 conf 等文件夹。没有映射到项目名称的文件夹,请有人告诉我如何列
对于我的图像位置:/src/assets/bitmap/sample.jpg 给出了关键配置: context: resolve('src') output: { path: resolve('b
我需要创建带有圆角的 SVG 路径,以将它们导出到 DXF 进行切割。我的问题是角应该是圆弧,而不是贝塞尔曲线。 使用 arc 命令相对容易处理直角,因为半径也是从拐角到圆弧起点的距离。对于其他角度,
大家好,我正在玩 Airflow,我正在阅读这篇很有帮助的 tutorial .我正在寻求帮助以更好地了解 Admin->Connection 如何在 Conn Type: File (path) 方
我的目标是定义R将用于安装和搜索库的单个路径。我read可以通过更改Rprofile.site安装路径中的R文件来完成。我在那里尝试了两个命令: .libPaths("D:/RLibrary") .L
我有一个问题:当我在一个页面中时,我想返回到上一页。我使用 $routeProvider。如何读取之前的 url? 我尝试在我的 Controller 中使用此代码但不起作用... angular.m
我正在尝试将一个文件从我的主干合并到一个分支(wc),并且对于看起来位于当前合并操作中不涉及的分支上的路径出现奇怪的未找到路径错误。 例如,在我们的 svn 项目中,我们有: 分行 分支 0 分支 1
我有一个树数据序列化如下: 关系:P到C是“一对多”,C到P是“一对一”。所以列 P 可能有重复的值,但列 C 有唯一的值。 P, C 1, 2 1, 3 3, 4 2, 5 4, 6 # in da
我是一名优秀的程序员,十分优秀!