修改密码

请输入密码
请输入密码 请输入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

      深度优先搜索(DFS)

      HDC

      概述

      图遍历(Graph Traversal)是一种系统性的搜索技术,用于访问和探索图中的所有节点。图遍历的主要目标是发现和检查图的结构和连接关系。图遍历有两种常见的策略:

      • 广度优先搜索(Breadth-First Seach, BFS)
      • 深度优先搜索(Depth-First Seach, DFS)

      深度优先搜索(DFS)算法基于回溯(Backtracking)原则,具体实现步骤如下:

      1. 创建一个(后进先出)来跟踪已访问的节点。
      2. 从选择的起始节点开始,将其推入栈,并标记该节点为已访问。
      3. 将位于栈顶的节点的任意一个未访问邻居推入栈,并标记为已访问。如果有多个未访问邻居,任意选择一个或按照某种确定的顺序进行选择。
      4. 重复第3步,直到没有更多未访问的邻居可以推入栈。
      5. 当没有新节点可以访问时,通过从栈中弹出顶部节点回溯到前一个节点(即当前节点是从哪个节点探索而来的)。
      6. 重复第3、4和5步,直到栈为空。

      下面是以DFS方式遍历图的示例,以节点A作为起始节点,并假定按字母顺序(A~Z)访问邻居节点:

      特殊说明

      • 只有与起始节点在同一个连通分量中的节点才能被遍历。不同连通分量中的节点将不会出现在结果中。

      示例图集

      创建示例图集:

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

      创建HDC图集

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

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

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

      参数

      算法名:traverse

      参数名
      类型
      规范
      默认值
      可选
      描述
      ids _id / / 通过_id指定遍历的起点
      uuids _uuid / / 通过_uuid指定遍历的起点
      direction String in, out / 指定遍历时的边方向,in表示仅遍历入边,out表示仅遍历出边
      traverse_type String dfs bfs 以DFS方式遍历图时,设置该项为dfs
      return_id_uuid String uuid, id, both uuid 在结果中使用_uuid_id或同时使用两者来表示点

      文件回写

      CALL algo.traverse.write("hdc_trv", {
        params: {
          return_id_uuid: "id",
          ids: ['B'],
          direction: 'in',
          traverse_type: 'dfs'
        },
        return_params: {
          file: {
            filename: "visited_nodes"
          }
        }
      })
      

      algo(traverse).params({
        project: "hdc_trv",
        return_id_uuid: "id",
        ids: ['B'],
        direction: 'in',
        traverse_type: 'dfs'
      }).write({
        file: {
          filename: "visited_nodes"
        }
      })
      

      结果:

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