修改密码

请输入密码
请输入密码 请输入8-64长度密码 和 email 地址不相同 至少包括数字、大写字母、小写字母、半角符号中的 3 个
请输入密码
提交

修改昵称

当前昵称:
提交

申请证书

证书详情

Please complete this required field.

  • Ultipa Graph V4

Standalone

Please complete this required field.

Please complete this required field.

服务器的MAC地址

Please complete this required field.

Please complete this required field.

取消
申请
ID
产品
状态
核数
申请天数
审批时间
过期时间
MAC地址
申请理由
审核信息
关闭
基础信息
  • 用户昵称:
  • 手机号:
  • 公司名称:
  • 公司邮箱:
  • 地区:
  • 语言:
修改密码
申请证书

当前未申请证书.

申请证书
Certificate Issued at Valid until Serial No. File
Serial No. Valid until File

Not having one? Apply now! >>>

ProductName CreateTime ID Price File
ProductName CreateTime ID Price File

No Invoice

v5.0
搜索
    v5.0

      拓扑排序

      HDC

      概述

      有向图的拓扑排序(Topological Sort)是指将图中的节点按照一定的顺序进行排列,使得每条边的起点在终点之前。需要注意的是,拓扑排序仅适用于有向无环图(DAG)。

      拓扑排序在计算机科学和其他领域有着各种应用。在项目管理和作业调度中,拓扑排序能够根据任务之间的依赖关系确定任务执行的最佳顺序。它还可用于解决软件开发中模块、库或组件之间的依赖关系。这一算法可以按照正确的顺序解决依赖关系,减少冲突和潜在错误的发生。

      基本概念

      有向无环图(DAG)

      有向无环图(Directed Acyclic Graph, DAG)是指不存在有向环路(Cycle)的有向图。换句话说,在DAG中无法从任意一个节点v出发,经过一条有向路径后又回到节点v。

      如下所示,第一个和第二个图是DAG,而第三个图中包含一个有向循环(B→C→D→B),不符合DAG的定义。

      是否可以进行拓扑排序常作为判断一个有向图是否为DAG的标准。

      拓扑排序

      每个DAG至少有一种拓扑排序。

      在上述示例中,第一个图中的节点有3种可能的排序:

      • A, E, B, D, C
      • A, B, E, D, C
      • A, B, D, E, C

      当DAG中存在包含所有节点的有向路径时,DAG才具有唯一的拓扑排序,此时排序与路径中节点出现的顺序相同。

      在下面的示例中,图中的节点只有1种可能的排序:A, B, D, C, E, F。

      特殊说明

      在存在环路的图上运行拓扑排序算法将导致一些节点在排序中被忽略掉,被忽略的节点包括:

      • 环路(包括自环)中的节点;
      • 环路中的节点通过出边能触达的其他节点。

      在以下的示例中,首先忽略环路中的节点C、D和G,其次忽略从环路节点出边可达的其他节点,包括节点F、J和H。下图拓扑排序结果为:A, I, B, E。

      如果一个图是非连通的,或是因为忽略上述构成环路和受环路影响的节点后变成非连通,拓扑排序会分别在每个连通分量内进行,并统一返回排序结果。孤点也不会被忽略。

      示例图集

      创建示例图集:

      // 在空图集中逐行运行以下语句
      insert().into(@default).nodes([{_id:"A"}, {_id:"B"}, {_id:"C"}, {_id:"D"}, {_id:"E"}, {_id:"F"}, {_id:"G"}, {_id:"H"}])
      insert().into(@default).edges([{_from:"A", _to:"B"}, {_from:"A", _to:"C"}, {_from:"A", _to:"D"}, {_from:"A", _to:"E"}, {_from:"E", _to:"G"}, {_from:"F", _to:"D"}, {_from:"F", _to:"E"}, {_from:"H", _to:"G"}])
      

      创建HDC图集

      将当前图集全部加载到HDC服务器hdc-server-1上,并命名为 hdc_topo_sort

      CALL hdc.graph.create("hdc-server-1", "hdc_topo_sort", {
        nodes: {"*": ["*"]},
        edges: {"*": ["*"]},
        direction: "undirected",
        load_id: true,
        update: "static",
        query: "query",
        default: false
      })
      

      hdc.graph.create("hdc_topo_sort", {
        nodes: {"*": ["*"]},
        edges: {"*": ["*"]},
        direction: "undirected",
        load_id: true,
        update: "static",
        query: "query",
        default: false
      }).to("hdc-server-1")
      

      参数

      算法名:topological_sort

      参数名
      类型
      规范
      默认值
      可选
      描述
      return_id_uuid String uuid, id, both uuid 在结果中使用_uuid_id或同时使用两者来表示点;该选项仅在文件回写模式下生效

      文件回写

      CALL algo.topological_sort.write("hdc_topo_sort", {
        params: {
          return_id_uuid: "id"
        },
        return_params: {
          file: {
            filename: "sort"
          }
        }
      })
      

      algo(topological_sort).params({
        project: "hdc_topo_sort",
        return_id_uuid: "id"
      }).write({
        file: {
          filename: "sort"
        }
      })
      

      结果:

      _id
      F
      H
      A
      B
      C
      D
      E
      G
      

      完整返回

      CALL algo.topological_sort("hdc_topo_sort", {
        params: {},
        return_params: {}
      }) YIELD result
      RETURN result
      

      exec{
        algo(topological_sort).params() as result
        return result
      } on hdc_topo_sort
      

      [{"id":"F","uuid":"2882304861028745219","schema":"default","values":{}}]
      [{"id":"H","uuid":"3386708019294240772","schema":"default","values":{}}]
      [{"id":"A","uuid":"10016006670783610881","schema":"default","values":{}}]
      [{"id":"B","uuid":"3530823207370096641","schema":"default","values":{}}]
      [{"id":"C","uuid":"12033619303845593090","schema":"default","values":{}}]
      [{"id":"D","uuid":"288231475663339522","schema":"default","values":{}}]
      [{"id":"E","uuid":"10520409829049106435","schema":"default","values":{}}]
      [{"id":"G","uuid":"13690943966717935617","schema":"default","values":{}}]
      

      流式返回

      CALL algo.topological_sort("hdc_topo_sort", {
        params: {},
        return_params: {
          stream: {}
        }
      }) YIELD r
      FOR node IN r 
      RETURN node._id
      

      exec{
        algo(topological_sort).params({}).stream() as r
        uncollect r as node
        return node._id
      } on hdc_topo_sort
      

      结果:

      node._id
      F
      H
      A
      B
      C
      D
      E
      G
      请完成以下信息后可下载此书
      *
      公司名称不能为空
      *
      公司邮箱必须填写
      *
      你的名字必须填写
      *
      你的电话必须填写
      *
      你的电话必须填写