zoukankan      html  css  js  c++  java
  • python数据结构之图的实现方法

    python数据结构之图的实现方法

    本文实例讲述了python数据结构之图的实现方法。分享给大家供大家参考。具体如下:

    下面简要的介绍下:
    比如有这么一张图:

        A -> B
        A -> C
        B -> C
        B -> D
        C -> D
        D -> C
        E -> F
        F -> C

    可以用字典和列表来构建    
    graph = {'A': ['B', 'C'],
           'B': ['C', 'D'],
           'C': ['D'],
           'D': ['C'],
           'E': ['F'],
           'F': ['C']}

    找到一条路径:    
    def find_path(graph, start, end, path=[]):
        path = path [start]
        if start == end:
          return path
        if not graph.has_key(start):
          return None
        for node in graph[start]:
          if node not in path:
            newpath = find_path(graph, node, end, path)
            if newpath: return newpath
        return None

    找到所有路径:    
    def find_all_paths(graph, start, end, path=[]):
        path = path [start]
        if start == end:
          return [path]
        if not graph.has_key(start):
          return []
        paths = []
        for node in graph[start]:
          if node not in path:
            newpaths = find_all_paths(graph, node, end, path)
            for newpath in newpaths:
              paths.append(newpath)
        return paths

    找到最短路径:    
    def find_shortest_path(graph, start, end, path=[]):
        path = path [start]
        if start == end:
          return path
        if not graph.has_key(start):
          return None
        shortest = None
        for node in graph[start]:
          if node not in path:
            newpath = find_shortest_path(graph, node, end, path)
            if newpath:
              if not shortest or len(newpath) < len(shortest):
                shortest = newpath
        return shortest

    希望本文所述对大家的Python程序设计有所帮助。

  • 相关阅读:
    Openlayer 3 的画图测量面积
    Openlayer 3 的画线测量长度
    屏幕尺寸
    px和em,rem的区别
    水平和垂直居中
    Flex布局
    继承的几种方法及优缺点
    call ,apply 和 bind的用法与区别
    mybatis springmvc velocity的demo
    正则同时包含两个关键字
  • 原文地址:https://www.cnblogs.com/amengduo/p/9586743.html
Copyright © 2011-2022 走看看