前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Python高级数据结构——图论算法(Graph Algorithms)

Python高级数据结构——图论算法(Graph Algorithms)

作者头像
Echo_Wish
发布于 2023-12-03 02:50:53
发布于 2023-12-03 02:50:53
2K00
代码可运行
举报
运行总次数:0
代码可运行

Python中的图论算法(Graph Algorithms):高级数据结构解析

图是一种由节点(顶点)和边组成的数据结构,用于表示不同元素之间的关系。图论算法旨在解决与图相关的问题,例如路径查找、最短路径、最小生成树等。在本文中,我们将深入讲解Python中的图论算法,包括图的表示、常见算法、应用场景,并使用代码示例演示图论算法的操作。

基本概念
1. 图的表示

在Python中,图可以使用邻接矩阵或邻接表的方式进行表示。

  • 邻接矩阵 邻接矩阵是一个二维数组,其中 matrix[i][j] 表示顶点 i 和 j 之间是否有边。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class GraphAdjacencyMatrix:
    def __init__(self, num_vertices):
        self.num_vertices = num_vertices
        self.matrix = [[0] * num_vertices for _ in range(num_vertices)]

    def add_edge(self, start, end):
        self.matrix[start][end] = 1
        self.matrix[end][start] = 1

# 示例
graph_matrix = GraphAdjacencyMatrix(5)
graph_matrix.add_edge(0, 1)
graph_matrix.add_edge(1, 2)
graph_matrix.add_edge(2, 3)
graph_matrix.add_edge(3, 4)
  • 邻接表 邻接表使用字典来表示图,其中字典的键是顶点,对应的值是与该顶点相邻的顶点列表。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
from collections import defaultdict

class GraphAdjacencyList:
    def __init__(self):
        self.graph = defaultdict(list)

    def add_edge(self, start, end):
        self.graph[start].append(end)
        self.graph[end].append(start)

# 示例
graph_list = GraphAdjacencyList()
graph_list.add_edge(0, 1)
graph_list.add_edge(1, 2)
graph_list.add_edge(2, 3)
graph_list.add_edge(3, 4)
2. 图的遍历

图的遍历是访问图中所有节点的过程。常见的图遍历算法有深度优先搜索(DFS)和广度优先搜索(BFS)。

  • 深度优先搜索(DFS) DFS 通过递归或栈实现,从起始节点开始,尽可能深入到图中的节点,直到无法继续为止。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    print(start, end=" ")
    for neighbor in graph[start]:
        if neighbor not in visited:
            dfs(graph, neighbor, visited)

# 示例
dfs(graph_list.graph, 0)
  • 广度优先搜索(BFS) BFS 使用队列实现,从起始节点开始,逐层访问图中的节点。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
from collections import deque

def bfs(graph, start):
    visited = set()
    queue = deque([start])
    visited.add(start)
    while queue:
        current = queue.popleft()
        print(current, end=" ")
        for neighbor in graph[current]:
            if neighbor not in visited:
                queue.append(neighbor)
                visited.add(neighbor)

# 示例
bfs(graph_list.graph, 0)
常见算法
1. 最短路径算法
  • Dijkstra算法 Dijkstra算法用于求解单源最短路径,通过贪心策略逐步找到最短路径。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import heapq

def dijkstra(graph, start):
    distances = {vertex: float('infinity') for vertex in graph}
    distances[start] = 0
    priority_queue = [(0, start)]
    while priority_queue:
        current_distance, current_vertex = heapq.heappop(priority_queue)
        if current_distance > distances[current_vertex]:
            continue
        for neighbor, weight in graph[current_vertex].items():
            distance = current_distance + weight
            if distance < distances[neighbor]:
                distances[neighbor] = distance
                heapq.heappush(priority_queue, (distance, neighbor))
    return distances

# 示例
graph_weighted = {
    0: {1: 1, 2: 4},
    1: {0: 1, 2: 2, 3: 5},
    2: {0: 4, 1: 2, 3: 1},
    3: {1: 5, 2: 1}
}
shortest_distances = dijkstra(graph_weighted, 0)
print("Shortest Distances:", shortest_distances)
2. 最小生成树算法
  • Prim算法 Prim算法用于求解最小生成树,通过贪心策略逐步构建树。
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import heapq

def prim(graph):
    start_vertex = list(graph.keys())[0]
    visited = {start_vertex}
    edges = [
        (cost, start_vertex, to_vertex)
        for to_vertex, cost in graph[start_vertex].items()
    ]
    heapq.heapify(edges)
    minimum_spanning_tree = []
    while edges:
        cost, from_vertex, to_vertex = heapq.heappop(edges)
        if to_vertex not in visited:
            visited.add(to_vertex)
            minimum_spanning_tree.append((from_vertex, to_vertex, cost))
            for neighbor, neighbor_cost in graph[to_vertex].items():
                if neighbor not in visited:
                    heapq.heappush(edges, (neighbor_cost, to_vertex, neighbor))
    return minimum_spanning_tree

# 示例
graph_weighted = {
    'A': {'B': 1, 'C': 4},
    'B': {'A': 1, 'C': 2, 'D': 5},
    'C': {'A': 4, 'B': 2, 'D': 1},
    'D': {'B': 5, 'C': 1}
}
minimum_spanning_tree = prim(graph_weighted)
print("Minimum Spanning Tree:", minimum_spanning_tree)
图论算法的应用场景

图论算法在实际应用中有广泛的应用,包括但不限于:

  1. 网络路由: 通过图论算法优化数据包传输路径。
  2. 社交网络分析: 分析社交网络中的关系、影响力等。
  3. 城市规划: 规划最优路径、交通流等。
  4. 推荐系统: 基于用户和物品之间的关系进行推荐。
总结

图论算法是解决与图相关问题的重要工具,它涵盖了图的表示、遍历、最短路径、最小生成树等多个方面。在Python中,可以使用字典等数据结构来表示图,通过深度优先搜索、广度优先搜索、Dijkstra算法、Prim算法等实现图论算法。理解图论算法的基本概念、实现方式和应用场景,将有助于更好地应用图论算法解决实际问题。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-12-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
OAuth 2.0 极简教程 (The OAuth 2.0 Authorization Framework)
OAuth(开放授权)是一个开放标准,允许用户授权第三方移动应用访问他们存储在另外的服务提供者上的信息,而不需要将用户名和密码提供给第三方移动应用或分享他们数据的所有内容,OAuth2.0 不兼容OAuth 1.0 。
一个会写诗的程序员
2020/10/29
3.4K0
OAuth 2.0 极简教程 (The OAuth 2.0 Authorization Framework)
OAuth 2.0验证【面试+工作】
OAuth2.0验证【面试+工作】 OAuth是一个关于授权(authorization)的开放网络标准,在全世界得到广泛应用,目前的版本是2.0版。 本文对OAuth 2.0的设计思路和运行流程,
Java帮帮
2018/03/15
1.9K0
OAuth 2.0验证【面试+工作】
全面介绍SSO(单点登录)
SSO英文全称Single SignOn,单点登录。SSO是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。它包括可以将这次主要的登录映射到其他应用中用于同一个用户的登录的机制。它是目前比较流行的企业业务整合的解决方案之一。
蒋老湿
2019/12/12
5.1K0
OAuth 2.0 授权认证详解
点击上方“芋道源码”,选择“设为星标” 管她前浪,还是后浪? 能浪的浪,才是好浪! 每天 10:33 更新文章,每天掉亿点点头发... 源码精品专栏 原创 | Java 2021 超神之路,很肝~ 中文详细注释的开源项目 RPC 框架 Dubbo 源码解析 网络应用框架 Netty 源码解析 消息中间件 RocketMQ 源码解析 数据库中间件 Sharding-JDBC 和 MyCAT 源码解析 作业调度中间件 Elastic-Job 源码解析 分布式事务中间件 TCC-Transaction
芋道源码
2022/06/20
2K0
OAuth 2.0 授权认证详解
OAuth 2 深入介绍
更友好的阅读体验,请转至 OAuth 深入介绍 。 1. 前言 2. OAuth2 角色 2.1 资源所有者(Resource Owner) 2.2 资源/授权服务器(Resource/Authorization Server) 2.3 客户端(Client) 3. OAuth 2 的授权流程 4. 客户端应用注册 4.1 Client ID 和 Client Secret 5. 授权许可(Authorization Grant) 5.1 Authorization Code Flow 1. User Au
潘成涛
2018/05/28
3.8K0
Spring Boot2.0 Oauth2 服务器和客户端配置及原理
有一个"云冲印"的网站,可以将用户储存在Google的照片,冲印出来。用户为了使用该服务,必须让"云冲印"读取自己储存在Google上的照片。
chinotan
2019/04/03
4.3K0
Spring Boot2.0 Oauth2 服务器和客户端配置及原理
OAuth2.0认证解析
OAuth是一个关于授权(authorization)的开放网络标准,在全世界得到广泛应用,目前的版本是2.0版。
FB客服
2020/11/16
4.9K0
OAuth2.0认证解析
OAuth 2.0一键登录那些事
程序员对Gitee和Github都不陌生,Github可能是起源时间最早、用户范围最大的代码开源仓库,Gitee作为国产代码仓库的后起之秀,在用户模块也是做到了兼容Github的功能,如,在Gitee的登录界面可以通过Github授权的方式登录。这就是今天我要讲的OAuth 2.0,大家可以去Gitee体验一下UI交互流程,以更形象的理解OAuth 2.0的授权流程。
关忆北.
2022/06/27
5510
OAuth 2.0一键登录那些事
Spring Security 与 OAuth2 介绍
OAuth2 角色 resource owner:资源所有者(指用户) resource server:资源服务器存放受保护资源,要访问这些资源,需要获得访问令牌(下面例子中的 Twitter 资源服务器) client:客户端代表请求资源服务器资源的第三方程序(下面例子中的 Quora)客户端同时也可能是一个资源服务器 authrization server:授权服务器用于发放访问令牌给客户端(下面例子中的 Twitter 授权服务器) OAuth2 工作流程例子 客户端 Quora 将自己注册到授
朝雨忆轻尘
2019/06/18
1.5K0
oauth2.0的授权流程详解
1、 在客户端web项目中构造一个oauth的客户端请求对象(OAuthClientRequest),在此对象中携带客户端信息(clientId、accessTokenUrl、response_type、redirectUrl),将此信息放入http请求中,重定向到服务端。此步骤对应上图1
Dream城堡
2018/09/10
3.8K0
oauth2.0的授权流程详解
理解OAuth2.0认证与客户端授权码模式详解
OAuth 协议为用户资源的授权提供了一个安全又简易的标准。与以往的授权方式不同之处是 OAuth的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 OAuth是安全的。OAuth 是 Open Authorization 的简写
BUG弄潮儿
2021/04/12
6.2K0
OAuth2.0 认证
密码模式(Resource owner password credentials)流程
谢公子
2022/01/20
1.6K0
OAuth2.0 认证
OAuth2 认证
随着微服务的兴起,OAuth2也火了起来,由于其自身的优势,俨然已成为微服务API服务接口安全防护的首选。
BUG弄潮儿
2022/04/15
6540
OAuth2 认证
oauth2.0的学习与使用
栗子一: 小新现在想要使用一个“在线打印服务”来打印一些照片,同时小新的照片都存储在了“云网盘”上,按照传统的方式小新要怎么做呢?
向着百万年薪努力的小赵
2022/12/02
9520
OAuth 2.0 的探险之旅
OAuth 2.0 全称是 Open Authorization 2.0, 是用于授权(authorization)的行业标准协议。OAuth 2.0 专注于客户端开发人员的简单性,同时为 Web 应用程序、桌面应用程序、移动设备应用等提供了特定的授权流程。它在2012年取代了 OAuth 1.0, 并且 OAuth 2.0 协议不向后兼容 OAuth 1.0。
全球技术精选
2021/11/12
1.8K0
OAuth 2.0 的探险之旅
OAuth2.0授权协议
通过用户授权,第三方服务访问用户存在其他服务上的资源,而不需用户将用户名密码直接传递的资源服务器的安全控制协议。
sucl
2019/09/05
7450
OAuth2.0授权协议
OAuth2.0授权码模式
本文链接:https://blog.csdn.net/u014427391/article/details/97504088
SmileNicky
2019/08/29
1.2K0
OAuth2.0授权码模式
[认证授权] 1.OAuth2授权
1 OAuth2解决什么问题的? 举个栗子先。小明在QQ空间积攒了多年的照片,想挑选一些照片来打印出来。然后小明在找到一家提供在线打印并且包邮的网站(我们叫它PP吧(Print Photo缩写 ?))
blackheart
2018/01/19
1.9K0
[认证授权] 1.OAuth2授权
Oauth协议介绍与安全隐患
OAuth 是一个开放标准,允许用户让第三方应用访问该用户在某一网站上存储的私密的资源(如照片,视频,联系人列表),而无需将用户名和密码提供给第三方应用。目前,OAuth 的最新版本为 2.0
信安之路
2018/08/08
1.4K0
Oauth协议介绍与安全隐患
从协议入手,剖析OAuth2.0(译 RFC 6749)
      传统的client-server授权模型,客户端通过使用凭证(通常的用户名和明文密码)访问服务端受保护的资源,为了能够让第三方应用程序访问受保护的资源,需要将凭证共享给第三方。
justmine
2022/05/10
5.3K0
相关推荐
OAuth 2.0 极简教程 (The OAuth 2.0 Authorization Framework)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验