zoukankan      html  css  js  c++  java
  • All shortest paths between a set of nodes

    Consider a number of arbitrary nodes, A,B,C,D,E,F,…​..

    I wish to return all of the shortest paths between these nodes. The nodes may have many edges between them, but anticipate a maximum of 4. The graph is complex and non hierarchical (if this makes sense – any node may point to any other node). A typical node has the form: match (n:Entity { name: 'xyz' })

    How would I write the match expression to return the shortest paths between the above nodes, in no specific order?

    Solution

    1. Find the set of nodes using an indexed lookup operation
    2. Collect them into a list
    3. Unwind the list twice, once for every side of the path
    4. Remove inverse pairs by id comparison
    5. match and return the paths
    MATCH (n:Entity) where n.name IN [names]
    WITH collect(n) as nodes
    UNWIND nodes as n
    UNWIND nodes as m
    WITH * WHERE id(n) < id(m)
    MATCH path = allShortestPaths( (n)-[*..4]-(m) )
    RETURN path

    原文地址:https://neo4j.com/developer/kb/all-shortest-paths-between-set-of-nodes/

  • 相关阅读:
    MySQL 修改表结构
    mysql中Timestamp,time,datetime 区别
    ERROR 1018 (HY000): Can't read dir of './test/' (errno: 13)
    Jquery报错:Uncaught TypeError: ((m.event.special[e.origType] || (intermediate value)).handle || e.handler).apply is not a function
    Python之No module named setuptools 安装pip
    这个快压到底是什么逗比?
    文档批量格式化之word技能
    连八进制都不知道
    python的异常小结与assert
    python 中的input
  • 原文地址:https://www.cnblogs.com/jpfss/p/11652218.html
Copyright © 2011-2022 走看看